zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

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

2023-03-31 11:11:18 时间

本文介绍了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的安装目录(类似 ~appAdministratorproduct11.1.0client_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编程之把过程与函数说透