在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
老板要求我搭个ASP.NET框架,并且连接上ORACLE数据库,听起来好像挺简单的,但就是连第一步连接ORACLE我都搞了两天╮(╯▽╰)╭ 首先,项目书上要求用ORACLE 10G,可我自己的本本装的WIN8,尝试地装了下ORACLE 10G失败,而且界面丑的一笔,于是放弃治疗了。 上ORACLE官网看了下,现在都出到ORACLE 12c了,果断来了一发,照着网上的安装教程磕磕巴巴终于装上了。教程如下地址: 这里,我设置的全局数据库名是orcl,密码为Oracle12c(好像ORACLE的密码必须要有大小写配合)。 安装完毕之后,用自带的SQL Plus登录进去,用户名为SYSTEM,密码为Oracle12c,ORACLE比较操蛋啊,之前在MYSQL的语句都不好用了。 总结几条: 1 // 查询所有表(分号一定要有) 2 select table_name from all_tables; 3 4 // 查询用户下的所有表 5 select table_name from user_tables; 6 7 // 显示表内数据 8 select * from myoracle; 有点兴奋,可是好戏在后头 .. 我一直在寻找PLSQL Developer,找了半天咋没有呢 .. 在东软电脑上都有啊,百度了一下原来他妈的这玩意还要自己装。 ORACLE官网上木有这玩意,我在其他地方下了一个,装上,发现不好使,他妈的,郁闷了,这时候不懂怎么办了。 各种百度啊,并且在visual studio12里写代码测试能不能连上,虽然百度上方法很多,可是没一个能好用的,真是纠结出翔。 偶然我怀疑是不是有组件没装,又是各种百度,居然真是!我还没装ORACLE客户端!真笨啊!搞了半天才发现这么傻的问题! 我的ORACLE是12c release 12.1.0.1.0的,所以下了ODTwithODAC121010包,里面包括: 虽然找到了原因,但这时候我又担心不会把这些组件都装上以后又有什么新问题吧,果然不出我所料!妈瞎啊妈瞎真是fuck啊! 各种试,试了PLSQL Developer不行,试了visual studio12里的ODBC,OLE DB,ODP.NET托管驱动程序还是不行!
然后我又是各种百度啊!各种试各种不成功!到最后,终于有一个好用的了!那就是: 在D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\NETWORK\ADMIN\ listener.ora里加上一些配置。 本来是这样的: 1 # listener.ora Network Configuration File: D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\network\admin\listener.ora 2 # Generated by Oracle configuration tools. 3 4 SID_LIST_LISTENER = 5 (SID_LIST = 6 (SID_DESC = 7 (SID_NAME = CLRExtProc) 8 (ORACLE_HOME = D:\MySoftware\app\gomez\product\12.1.0\dbhome_1) 9 (PROGRAM = extproc) 10 (ENVS = "EXTPROC_DLLS=ONLY:D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\bin\oraclr12.dll") 11 ) 12 ) 13 14 LISTENER = 15 (DESCRIPTION_LIST = 16 (DESCRIPTION = 17 (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) 18 (ADDRESS = (PROTOCOL = TCP)(HOST = WMW-PC)(PORT = 1521)) 19 ) 20 ) 修改后是这样的: 1 # listener.ora Network Configuration File: D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\network\admin\listener.ora 2 # Generated by Oracle configuration tools. 3 4 SID_LIST_LISTENER = 5 (SID_LIST = 6 (SID_DESC = 7 (GLOBAL_HOME = orcl) 8 (ORACLE_HOME = D:\MySoftware\app\gomez\product\12.1.0\dbhome_1) 9 (SID_NAME = ORCL) 10 ) 11 (SID_DESC = 12 (SID_NAME = CLRExtProc) 13 (ORACLE_HOME = D:\MySoftware\app\gomez\product\12.1.0\dbhome_1) 14 (PROGRAM = extproc) 15 (ENVS = "EXTPROC_DLLS=ONLY:D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\bin\oraclr12.dll") 16 ) 17 ) 18 19 LISTENER = 20 (DESCRIPTION_LIST = 21 (DESCRIPTION = 22 (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521)) 23 (ADDRESS = (PROTOCOL = TCP)(HOST = WMW-PC)(PORT = 1521)) 24 ) 25 ) ------------------------------------------------- 还有就是本来在装完客户端之后,D:\MySoftware\app\gomez\product\12.1.0\client_1\Network\Admin这个路径下只有Sample文件夹, 参照D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\NETWORK\ADMIN,这里不仅有Sample文件夹,还有listener.ora,tnsnames.ora,sqlnet.ora还有sqlnet13122912下午2119.bak(本来想用xxx等 .. 感觉程序员还是不要那么马虎), 所以我就把D:\MySoftware\app\gomez\product\12.1.0\client_1\Network\Admin\Sample里的sqlnet.ora和tnsnames.ora都拷出来,不知道有没有用(*^__^*) ------------------------------------------------- 然后重启服务OracleOraDB12Home1TNSListener,再试一试PLSQL,我擦进去了! 吊炸天了,赶紧试一试ODP.NET,也可以了!
然后接下来就是怎么用语句来实现对ORACLE数据库的查看、存储等等操作了。 先在ODTwithODAC121010里找到Oracle.DataAccess.Client.dll,具体位置是ODTwithODAC121010\stage\Components\oracle.ntoledb.odp_net_2\12.1.0.1.0\1\DataFiles里的filegroup10.jar,解压可得到Oracle.DataAccess.Client.dll,再将其添加到本项目的引用中来,然后在代码里添加using。 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using System.Data.Odbc; 7 using Oracle.DataAccess.Client; 8 9 namespace ConsoleApplication1 10 { 11 class Program 12 { 13 static void Main(string[] args) 14 { 15 // 连接数据库 16 string conn = "DATA SOURCE=ORCL;PERSIST SECURITY INFO=True;USER ID=SYSTEM;Password=Oracle12c"; 17 OracleConnection odpCon = new OracleConnection(conn); 18 odpCon.Open(); 19 20 // 插入数据 21 string sqlinsert = "insert into myoracle values(6,'yh')"; 22 using (OracleCommand comm_insert = new OracleCommand(sqlinsert, odpCon)) 23 { 24 using (OracleDataReader rdr_insert = comm_insert.ExecuteReader()) 25 { 26 27 } 28 } 29 30 // 查询数据 31 string sqlselect = "select * from myoracle"; 32 using (OracleCommand comm = new OracleCommand(sqlselect, odpCon)) 33 { 34 using (OracleDataReader rdr = comm.ExecuteReader()) 35 { 36 while (rdr.Read()) 37 { 38 Console.Write("ID "); 39 Console.Write(rdr.GetString(0)); 40 Console.Write(", NAME: "); 41 Console.WriteLine(rdr.GetString(1)); 42 } 43 } 44 } 45 } 46 } 47 } 代码很简单,不想解释了,跑起来是酱紫的。
好,到此为止,我已经可以在win8操作系统下用ODP.NET在visual studio 2012里利用代码连接到ORACLE 12C做一些必要操作了。 ------------------------------------------------- 还有问题么?有的!ODBC,OLE DB等等还是不行! ODBC数据源配置还是不好搞,搞来搞去还是错的!
非常不理想啊!说是体系结构不匹配,我的操作系统是64位的,数据库也是64位的,客户端没说是多少位的,ODBC数据源32和64的都设置过都不行。 还有OLE DB也还是不行,据visual studio 2012提示说可供连接到的最高版本为10g,那还玩个毛线! 还有一种!好像visual studio 2012的“引用”里面都没有这个库了 %>_<%
╮(╯▽╰)╭哎,ODBC & OLE DB & Oracle Client 这3种方法我暂时就放弃治疗了 .. 等过几天可能要在其他电脑搭XP+Oracle 10g什么的时候 .. 那个时候应该绕不过去这个了,那时候有进展再来详述,今天总算不是没有收获了!接来下加油继续搞下去!
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论