昨天晚上刚装好Oracle12c并配制好了PLSQL Developer开发环境。今天继续完善一下,讲讲在C#中如何访问Oracle12c。

其实我们运用老早的ADO.NET也可以连接,但是在.NET Framework4.0开始,已经不推荐使用。如果我们还是引用System.Data.OracleClient,在程序代码中使用OracleConnection、OracleCommand等数据库核心操作类时会有绿色的波浪线提示你该类已经过时。

把鼠标放到绿色波浪线处,会有如下提示:

它说System.Data.OracleClient.OracleConnection类已经过时,后面给出了一个微软官方的链接。

我们打开浏览器输出如上网址:http://go.microsoft.com/fwlink/?linkID=144260。如果你英文不行,可以用这个地址:http://msdn.microsoft.com/zh-cn/library/77d8yct7.aspx。

网址里面的说明非常直观:

这里需要说明的是,虽然提示已经过时,但是程序还是运行的。只不过微软官方建议使用更加高效的第三方Oracle提供程序。

下面就正式介绍Oracle提供的比ADO.NET更高效连接的ODAC(Oracle Data Access Components)组件。

这个组件同样可以在官方网站下面下载到。http://www.oracle.com/technetwork/database/windows/downloads/index-090165.html

我们根据自己之前安装的Oracle的版本选择合适的版本进行下载。因为我之前是装的Oracle 12c R1版本并且是64位的,因此我们选择如下图所示的文件进行下载。

下载好之后,解压到文件夹下面,运行setup.exe文件,进行安装。我们下的这个版本是支持VS2010和VS2012的,由于我装的是VS2012,安装过程中需要手动选择一下安装到VS2012,其它都是下一步。安装时间不长,耐心等待至安装完毕后退出。

环境准备好,我们就可以测试一下在VS2012中能否连接到Oracle 12c了。

测试过程很简单:

打开VS2012,选择菜单栏中的视图,然后选择服务器资源管理器。在数据连接上面右键鼠标,在弹出的菜单栏中选择添加连接后会打开如下页面。输入账号、密码等要素后, 点击测试连接按钮可以得到连接反馈(成功或失败)。

如果弹出“测试连接成功。”的提示,则表明我们通过Oracle提供的ODAC组件成功连接Oracle 12c了。

紧接着我们就可以在VS中写代码来测试一下,我们还是用上面的测试用例,输出当前数据库的系统时间。

首先我们要在项目中引用Oracle.DataAccess,然后就可以模仿ADO.NET的代码来写ODP.NET的代码了。

string connString = "Data Source=orcl;User ID=C##guwei4037;Password=123456;DBA Privilege=SYSDBA;";
using (Oracle.DataAccess.Client.OracleConnection conn = new Oracle.DataAccess.Client.OracleConnection(connString))
{
if (conn.State != ConnectionState.Open) conn.Open();//打开数据库连接 Oracle.DataAccess.Client.OracleCommand cmd = new Oracle.DataAccess.Client.OracleCommand("select sysdate from dual", conn);//执行一条SQL语句
object obj = cmd.ExecuteScalar();//返回第一行第一列的结果
Console.WriteLine(obj != null ? obj.ToString() : "null");
}

我们运行一下这个控制台应用程序。

OK,成功输出数据库系统时间,通过ODAC访问Oracle12c成功。

C#通过ODAC访问Oracle12c的更多相关文章

  1. ODAC访问oracle时,提示:由于以前的函数求值超时,函数求值被禁用,必须继续执行才能正常返回

    这是因为调试时会自动对Local/Watch等窗口里面(或鼠标停留所在)的变量求值,为了防止用户写的程序错误(比如死循环),系统有一个超时限制,如果某个属性的get中做了很复杂的操作(而不是简单地返回 ...

  2. ORA-01033: ORACLE initialization or shutdown in progress问题

    这是Oracle12c中笔者遇到的一个错误提示:ORA-01033: ORACLE initialization or shutdown in progress 错误的中文意思是:Oracle初始化未 ...

  3. Oracle数据访问组件ODAC的安装方法

    Oracle数据访问组件ODAC(Oracle Data Access Components)顾名思义就是用来访问Oracle数据库的小程序.我们可以编程调用这些组件来实现在没有安装Oracle数据库 ...

  4. Oracle数据访问组件ODAC的安装方法:

    Oracle数据访问组件ODAC(Oracle Data Access Components)顾名思义就是用来访问Oracle数据库的小程序.我们可以编程调用这些组件来实现在没有安装Oracle数据库 ...

  5. ODAC(V9.5.15) 学习笔记(十六)直接访问模式

    直接访问模式(Direct mode)是ODAC最大的特色之一,即不需要安装Oracle客户端,ODAC越过了OCI(Oracle Call Interface ),使用TCP/IP协议就可以直接与O ...

  6. 装Oracle12C时遇到没有权限访问临时位置的解决方法

    今天在装oracle12c是遇到了一个很奇怪的问题,显示是没有权限访问临时位置,可是我明明是用管理员的账号登陆的啊,最后在包姐的帮助下解决了,知其然,而我却不知其所以然.但还是把方法写下,希望能帮到一 ...

  7. 解决oracle12c安装报“[INS-30131]执行安装程序验证所需的初始设置失败(原因:无法访问临时位置)”方法

    安装过很多次oracle,顺顺利利的,今天在新机子上安装oracle12c client过程中竟然神奇的报出一个错误: 很明显的,已经很明确的给出了安装失败的原因:无法访问临时位置!实际上,在安装数据 ...

  8. Oracle12C配置对外访问

    Oracle12C配置对外访问 第一步: 开放端口或者关闭防火墙 第二步: 配置Oracle net manager打开Net manager 修改为共享服务器 第三步: 配置连接数打开Databas ...

  9. .NET安装和配置Oracle数据访问组件(ODAC)

    Many ASP.NET applications access Oracle database for the data source. Oracle supports the .NET with ...

随机推荐

  1. file_put_contents() failed to open stream: Permission denied 问题解决

    很长时间没有写PHP了,今天突然有个需求要写一个保存文件的功能. function downloadFile( $url , $savePath = '' ) {     $fileName = ge ...

  2. CDOJ 1157 数列(seq) 分块+线段树

    数列(seq) Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1157 Desc ...

  3. 2015北京网络赛 A题 The Cats' Feeding Spots 暴力

    The Cats' Feeding Spots Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://hihocoder.com/contest/acm ...

  4. iOS快速集成检查更新

    一直以为Appstore有了检查版本是否更新的机制,我们在APP上做这个更新功能会被拒,但是也有看到一些APP也是做了这个更新功能的.因为在网上没有找到完全正确的方法能获取到iTunes里的数据的,于 ...

  5. mysql 源码调试方法

     http://blog.itpub.net/29254281/viewspace-1847415/ 其中吕海波老师分享的内容是 <调试Oracle二三例:调试技术在日常运维中的应用>其中 ...

  6. java常用的包的简介

    java常用的包: java.lang:包含java语言的核心类,如String.math.system和thread类等,使用这个包下的类无需import导入,系统会自动导入这个包下的所有类.   ...

  7. sed示例

    引用:http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2856901.html [root@www ~]# sed [-nefr] [动作] 选 ...

  8. 预算oracle

    select * from ( )) CODE_VERSION from ( SELECT tb_cube_fc05.pk_entity pk_org,/*主体pk*/ org_orgs.code o ...

  9. 对list集合中的对象进行排序(转载)

    原文链接:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元 ...

  10. SQL Server(高级) 关键字的使用 二

    二, 高级 关键字 -- 使用介绍 8,Top 的使用(Top子句返回记录的数目) select top number|percent column_name(s) from table_name 或 ...