C#利用ODP.net连接Oracle数据库

数据库 Oracle
为了方便部署连接oracle的.net程序,oracle官方提供了一个简化版的client,即instant client。通过instant client和ODP.net中的Oracle.DataAccess.dll,我们就可以方便的部署.net应用程序或者站点。本文介绍了利用C#连接Oracle数据库的过程,供读者学习参考。

本文介绍了C#连接Oracle数据库的过程。通过instant client和ODP.net中的Oracle.DataAccess.dll,我们就可以方便的部署.net应用程序或者站点,而不需要安装Oracle客户端。接下来我们就介绍这一过程。

1. ODAC的安装

在oracle的官方网站上下载与你安装的oracle对应版本的ODAC。

下载地址:ODAC Download
下载好后解压安装,安装时不用安装全部的组件。主要安装以下组件:

  • Oracle Instant Client
  • Oracle Data Provider For .net2.0
  • Oracle rovider For Asp .net

2. 环境变量的设置

设置Windows的环境变量:

ORACLE_HOME :ODAC的安装目录(类似 ~\app\Administrator\product\11.1.0\client_1);

LD_LIBRARY_PATH :%ORACLE_HOME%;

TNS_ADMIN : %ORACLE_HOME%;

在PATH的最前面追加:%ORACLE_HOME%;

3. 监听文件tnsnames.ora的配置

在目录%ORACLE_HOME%下新建文件tnsnames.ora,内容如下:

  1. 数据库SID =  
  2.  
  3.   (DESCRIPTION =  
  4.  
  5.    (ADDRESS_LIST =  
  6.  
  7.       (ADDRESS = (PROTOCOL = TCP)(HOST = Oracle主机名或者IP)(PORT = 1521))  
  8.  
  9.     )  
  10.  
  11.     (CONNECT_DATA =  
  12.  
  13.       (SERVICE_NAME = 数据库SID)  
  14.  
  15.     )  
  16.  

4. plsqldev

这样配置好后,plsqldev就可以连接上oracle数据库了。

5. C#连接Oracle

C#连接oracle的示例代码如下:

  1. OracleConnection conn =  
  2.  
  3.     new OracleConnection();  
  4.  
  5. try  
  6.  
  7. {  
  8.  
  9.     conn.ConnectionString = ConfigurationManager.ConnectionStrings["oradb"].ConnectionString;  
  10.  
  11.     conn.Open();  
  12.  
  13.     string sql = " select id,content from test"; // C#  
  14.  
  15.     OracleCommand cmd = new OracleCommand(sql, conn);  
  16.  
  17.     cmd.CommandType = CommandType.Text;  
  18.  
  19.     OracleDataReader dr = cmd.ExecuteReader(); // C#  
  20.  
  21.     List<string> contents = newList<string>();  
  22.  
  23.     while(dr.Read())  
  24.  
  25.     {  
  26.  
  27.         contents.Add(dr["content"].ToString());  
  28.  
  29.     }  
  30.  
  31.     listBox1.ItemsSource = contents;  
  32.  
  33. }  
  34.  
  35. catch(Exception ex)  
  36.  
  37. {  
  38.  
  39.     MessageBox.Show(ex.Message);              
  40.  
  41. }  
  42.  
  43. finally  
  44.  
  45. {  
  46.  
  47.     conn.Clone();  
  48.  

在程序app.config或者web.config中追加数据库连接的配置。

  1. <connectionStrings > 
  2.  
  3.   <add name="oradb"connectionString="Data Source=(DESCRIPTION=  
  4.  
  5.        (ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.1)(PORT=1521)))  
  6.  
  7.        (CONNECT_DATA=(SERVICE_NAME=****)));  
  8.  
  9.        User Id=***;Password=***;"/> 
  10.  
  11. </connectionStrings> 

按照上述的步骤执行,如果没有错误,就可以成功地连接数据库了。

【编辑推荐】

  1. oracle job之存储过程处理的奥秘
  2. Oracle数据库的RAC组件之缓存融合技术
  3. 共享database独立Schema构建SAAS平台
  4. ASP通过Oracle Object for OLE对Oracle查询
  5. ORACLE数据库PL/SQL编程之把过程与函数说透
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-07-25 14:08:49

ODP.NETOracle实体数据模型

2010-10-26 15:21:11

连接Oracle数据库

2009-08-20 17:55:43

C#连接Oracle数

2010-10-26 15:30:12

连接Oracle数据库

2010-09-01 13:28:15

C#

2009-08-25 15:35:20

C#连接Oracle数

2009-08-24 18:09:13

C#调用Oracle数

2009-08-25 14:05:06

C#连接数据库代码

2009-09-04 17:23:21

C#数据库连接对象

2009-03-19 10:08:09

C#数据库查询

2009-08-25 15:50:13

C#连接远程数据库

2009-08-07 14:02:12

C#数据库连接字符串

2009-08-12 14:23:01

C#连接MySql数据

2009-09-04 17:49:34

C#连接数据库

2009-08-03 14:17:18

C#连接AccessC#连接SQL Ser

2009-08-06 18:03:21

C#相对路径

2009-08-18 11:23:11

2009-04-17 09:36:25

ASP.NETOracleWinform

2011-08-01 23:34:34

ASP.NETOracle

2010-05-14 09:08:10

C#Oracle
点赞
收藏

51CTO技术栈公众号