C# 连接Oracle(利用ODP.net,不安装oracle客户端)
来源:互联网 发布:开一家淘宝店的成本 编辑:程序博客网 时间:2024/05/16 15:59
摘自:http://www.cnblogs.com/wang_yb/archive/2011/07/11/2103368.html
为了方便部署连接oracle的.net程序,oracle官方提供了一个简化版的client,即instant client。
通过instant client和ODP.net中的Oracle.DataAccess.dll,我们就可以方便的部署.net应用程序或者站点。
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,内容如下:
数据库SID =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = Oracle主机名或者IP)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = 数据库SID)
)
)
4. plsqldev
这样配置好后,plsqldev就可以连接上oracle数据库了
5. C#连接Oracle
C#连接oracle的示例代码如下:
OracleConnection conn =
new
OracleConnection();
try
{
conn.ConnectionString = ConfigurationManager.ConnectionStrings[
"oradb"
].ConnectionString;
conn.Open();
string
sql =
" select id,content from test"
;
// C#
OracleCommand cmd =
new
OracleCommand(sql, conn);
cmd.CommandType = CommandType.Text;
OracleDataReader dr = cmd.ExecuteReader();
// C#
List<
string
> contents =
new
List<
string
>();
while
(dr.Read())
{
contents.Add(dr[
"content"
].ToString());
}
listBox1.ItemsSource = contents;
}
catch
(Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
conn.Clone();
}
在程序app.config或者web.config中追加数据库连接的配置
<
connectionStrings
>
<
add
name
=
"oradb"
connectionString="Data Source=(DESCRIPTION=
(ADDRESS_LIST=(ADDRESS=(
PROTOCOL
=
TCP
)(
HOST
=
192
.168.1.1)(
PORT
=
1521
)))
(CONNECT_DATA=(SERVICE_NAME=****)));
User Id=***;Password=***;"/>
</
connectionStrings
>
还可以参考官方的文档,不过是英文的,呵呵!
Build a .NET Application on the Oracle Database with Microsoft Visual Studio 2010
安装oraclclient运行时环境
ASP.NET连接Oracle问题1:System.Exception: System.Data.OracleClient requires Oracle client software version 8.1.7 or greater 原因:NTFS权限问题,在ORACLE9I时总是遇到 解决方法: 1、以管理员的用户登录; 2、找到ORACLE_HOME文件夹(我的是C:\oracle\ora92),点右键,选属性--安全,在组或用户栏中选“Authenticated Users”,在下面权限列表中把“读取和运行”的权限去掉,再按应用;重新选上“读取和运行”权限,点击应用;选权限框下面的“高级”按钮,确认“Authenticated Users”后面的应用于是“该文件夹、子文件夹及文件”,按确定把权限的更改应用于该文件夹;
或者
\app\Administrator\product\11.1.0 文件夹下 client_2 点右键,选属性--安全,在组或用户栏中选“Authenticated Users”,在下面权限列表中增加的修改权限,"应用";再去掉刚增加的权限,点击应用;选权限框下面的“高级”按钮,确认“Authenticated Users”后面的应用于是“该文件夹、子文件夹及文件”,按确定把权限的更改应用于该文件夹; 3、重新启动计算机,让权限设置生效(请注意,这一步很重要); 4、登录后运行asp.net应用,正常取得Oracle数据库的数据。
- C# 连接Oracle(利用ODP.net,不安装oracle客户端)
- C# 连接Oracle(利用ODP.net,不安装oracle客户端)
- C#利用ODP.net连接Oracle数据库的操作方法
- ORACLE客户端安装--ODP.NET用于VS2013
- asp.net 不安装客户端连接oracle
- .net 不安装客户端连接oracle
- C#远程连接Oracle数据库(不安装客户端)
- C#远程连接ORACLE(不安装客户端)
- Client使用c#和odp.net连接server oracle
- Client使用c#和odp.net连接server oracle
- Client使用c#和odp.net连接server oracle
- Client使用c#和odp.net连接server oracle[转]
- Client使用c#和odp.net连接server oracle
- C#不安装Oracle客户端连接Oracle数据库
- C#不安装Oracle客户端连接Oracle数据库
- asp.net 不安装Oracle客户端 连接 Oracle服务器
- 通过odp.net方式连接Oracle数据库
- 不安装oracle客户端连接oracle数据库
- 为Android应用程序读取/dev下设备而提权1
- 怎么样 下载 android 4.0源码,教你一下
- Wireshark
- android中LayoutInflater的使用(android.view.LayoutInflater)
- 向vg 里加 hdisk 时报错,解决如下
- C# 连接Oracle(利用ODP.net,不安装oracle客户端)
- 【Backward Compatibility for Applications】向后兼容程序
- 为Android应用程序读取/dev下设备而提权2
- 淘宝一些开源资源:分布式数据库,分布式文件系统,分布式缓存集群
- 面朝大海,春暖花开
- linux c调用链接库
- 获取Excel.dll
- 编译安装MYSYQL 的一点小问题
- VisionMobile:移动平台生态系统冲突报告(六)Chapter B:移动平台之战(下)