您的位置:首页 > 数据库 > Oracle

.net中连接Oracle 的两种方式:OracleClient,OleDb

2015-04-24 00:00 706 查看
.net中连接Oracle 的两种方式:OracleClient,OleDb

2015-04-24 00:00
2442人阅读 评论(0)
收藏
举报

本文章已收录于:


分类:
C#(6)




作者同类文章X

数据库(7)




作者同类文章X

.Net 中读写Oracle数据库常用两种方式:OracleClient和OleDb,其中OleDb的方式根据驱动程序的不同又有两种。

1. OracleClient方式,是微软专门针对Oracle数据库开发的,仅在 .NET Framework 1.1 版中受支持。据说速度快、性能好,是推荐使用的方式。但根据我的经验,当Oracle数据库服务器端采用英文字符集比如 US7ASCII 时,客户端不管字符集如何设置,读出的中文都是乱码;若服务器端用中文字符集比如
ZHS16GBK ,则无乱码问题。

引用类库:System.Data.OracleClient.dll。 

命名空间:System.Data.OracleClient。

常用类:OracleConnection、OracleCommand、OracleDataAdapter、OracleTransaction、OracleDataReader等。

典型连接字符串:“data source=oratest;user id=scott;password=tiger”(注意:可不指定 provider 驱动)。

2. OleDb方式,微软和Oracle公司各自提供了OleDb的驱动程序,使用方法的差别很少。不管Oracle服务器端用何字符集,读写中文均无乱码问题。

相同之处

命名空间:System.Data.OleDb。

常用类:OleDbConnection、OleDbCommand、OleDbDataAdapter、OleDbTransaction、OleDbDataReader等。

不同之处

引用类库:微软的只需要System.Data.dll;若用Oracle的驱动,虽然也只要引入System.Data.dll,但前提是首先安装Oracle针对.Net的数据访问组件

连接字符串:与OracleClient方式相比,要添加一个provider,微软为“provider=MSDAORA.1;”,Oracle为“provider='OraOleDb.Oracle';”。

string connString = "Provider=OraOLEDB.Oracle.1;User ID=IFSAPP;Password=IFSAPP;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT
= 1521))) (CONNECT_DATA = (SERVICE_NAME = RACE)))";

使用OleDB组件可以获得比OracleClient更高的效率和性能,因为OleDB是比ADO.NET更底层的组件,ADO.NET也要通过OleDB获取数据。

C# 连接 Oracle 的几种方式

http://www.cnblogs.com/storys/archive/2013/03/06/2945914.html

实例连接:

OleDbConnection conn=

         new OleDbConnection("Provider=OraOLEDB.Oracle.1;Server=localhost;

              Data  Source=(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)

                (HOST = localhost)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = mydb.bawei)));

              User ID=scott;Password=scott;");

    try{

    conn.Open();

    OleDbCommand comm=new OleDbCommand("select * from scott.emp",conn);

    OleDbDataReader dr=comm.ExecuteReader();

    Console.WriteLine("姓名      职位");

    while(dr.Read())

    {

          Console.WriteLine(dr.GetString(1)+"   "+dr.GetString(2));

    }

    Console.ReadLine();

    }finally{

    dr.Close();

    conn.Close();

    }



顶0踩0
 
 

上一篇在Visual Studio 2010中已经找不到直接创建WebService的模板方式
下一篇WebService部署
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: