C#通过ODAC访问Oracle12c

简介:

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

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

Center

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

Center

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

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

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

Center

这里需要说明的是,虽然提示已经过时,但是程序还是运行的。只不过微软官方建议使用更加高效的第三方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位的,因此我们选择如下图所示的文件进行下载。

Center

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

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

测试过程很简单:

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

Center

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

Center

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

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

1
2
3
4
5
6
7
8
9
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" );
}

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


Center

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




本文转自 guwei4037  51CTO博客,原文链接:http://blog.51cto.com/csharper/1352456

相关文章
|
15天前
|
C#
C# DataTable不能通过已删除的行访问该行的信息
C# DataTable不能通过已删除的行访问该行的信息
|
PyTorch API C#
【Python+C#】手把手搭建基于Hugging Face模型的离线翻译系统,并通过C#代码进行访问
目前翻译都是在线的,要在C#开发的程序上做一个可以实时翻译的功能,好像不是那么好做。而且大多数处于局域网内,所以访问在线的api也显得比较尴尬。于是,就有了以下这篇文章,自己搭建一套简单的离线翻译系统。以下内容采用python提供基础翻译服务+ C#访问服务的功能,欢迎围观。
933 0
【Python+C#】手把手搭建基于Hugging Face模型的离线翻译系统,并通过C#代码进行访问
|
15天前
|
JavaScript 前端开发 C#
C# webbrowser控件设置代理IP访问网站
C# webbrowser控件设置代理IP访问网站
199 5
|
15天前
|
程序员 C#
C# 面向对象编程进阶:构造函数详解与访问修饰符应用
构造函数是一种特殊的方法,用于初始化对象。构造函数的优势在于,在创建类的对象时调用它。它可以用于为字段设置初始值
48 1
|
10月前
|
C#
C#访问修饰符
C#访问修饰符
34 0
|
10月前
|
C#
C#视频—访问修饰符
C#视频—访问修饰符
|
11月前
|
SQL Oracle 网络协议
.Net项目中通过ODAC方式链接Oracle数据库相关配置
.Net项目中通过ODAC方式链接Oracle数据库相关配置 一、开发环境 1.关于ODAC的链接方式 ODAC 直接使用 Oracle 调用接口 (OCI). OCI 是一种允许应用程序开发人员使用第三方开发语言存取Oracle数据服务器的过程或函数以及控制所有的SQL语句执行状态的应用程序接口。 2.使用ODAC方式的优点 使用ODAC的Net选项而无需在客户机上安装Oracle客户端来连接到Oracle.在这种情况下,ODAC仅需要TCP/IP协议的支持,从而可以创建真正的、最小的数据库应用程序。
121 0
C#学习—访问修饰符和类型(静态)
C#学习—访问修饰符和类型(静态)
C#学习—访问修饰符和类型(静态)
C# 访问 C DLL
C# 访问 C DLL
62 0
|
网络协议 API C#
C#使用访问WMI的接口获取计算机硬件和操作系统信息,WMI代码生成器介绍【ManagementObjectSearcher、ManagementClass】
ManagementObjectSearcher 用于获取基于指定查询的管理对象集合。是获取管理信息最常用的入口点。例如,可以遍历所有的硬盘驱动、网络适配器、进程和系统上的其他管理对象,或者...
839 0
C#使用访问WMI的接口获取计算机硬件和操作系统信息,WMI代码生成器介绍【ManagementObjectSearcher、ManagementClass】