您的位置:首页 > 数据库

C#连接数据库的四种方法

2016-04-22 17:22 309 查看
/article/10326594.html

在进行以下连接数据库之前,请先在本地安装好Oracle Client,同时本次测试System.Data的版本为:2.0.0.0。

在安装Oracle Client上请注意,如果OS是3[b]-BIT请安装32-BIT的Oracle Client,但OS是64-BIT,需要根据实际情况安装,如果你的APP是按32-BIT运行的,则需要安装32-BIT客户端,如果是按64位运行的,则安装64位客户端,而不是OS是64-BIT的,就要安装64-BIT的ORACLE客户端。[/b]

本次测试会在32[b]-BIT 和64-BIT 上同时测试,32-BIT Oracle10G。[/b]


1.ODBC

1.1 首先需要在控制面板->管理工具->数据源(odbc)。

1.2 using System.Data.Odbc;

1.3 连接数据库

OdbcConnection conn = new OdbcConnection(DSN=XXX;UID=XXX;Pwd=XXX;);

conn.Open();

conn.Close();

32-BIT 和64-BIT 都OK。


2.OleDb

2.1 OleDB连接驱动有MSDAORA和OraOLEDB.Oracle,他们分别由微软和Oracle提供。使用OraOLEDB.Oracle驱动,需要安装Oracle Data Provider
for OLE DB 。在32位机器上两者都可以,在64位机器上,使用“MSDAORA”会出现“未在本地计算机上注册“MSDAORA.1”提供程序”的问题,OraOLEDB.Oracle一切正常。

2.2 连接数据库

//using System.Data.OleDb;

OleDbConnection conn = new OleDbConnection("Provider=MSDAORA.1;User ID=XXX;password=XXX;Data Source=XXX;Persist Security Info=False");
Provider需要根据实际情况修改

conn.Open();

conn.Close();


3.OracleClient

3.1 //using System.Data.OracleClient;

3.2 连接数据库

OracleConnection conn = new OracleConnection(“data source=XXX;user=XXX;password=XXX;”);

conn.Open();

conn.Close();

32[b]-BIT 和64-BIT 都OK。

[/b]


4.OracleDataAccess

4.1 //Using Oracle.DataAccess.Client 需要安装 Oracle Data Providerfor .NET Framework 2

4.2 连接数据库

Oracle.DataAccess.Client.OracleConnection conn = new Oracle.DataAccess.Client.OracleConnection("Data Source=yellow;user Id=Knemes;Password=oracle");

conn.Open();

conn.Close();

32-BIT 和64-BIT 都OK,但需要注意你的版本。

/article/5512007.html



一:通过System.Data.OracleClient(需要安装Oracle客户端并配置tnsnames.ora)

1. 添加命名空间System.Data.OracleClient引用

2. using System.Data.OracleClient;

3.

string connString = "User ID=IFSAPP;Password=IFSAPP;Data Source=RACE;";

OracleConnection conn = new OracleConnection(connString);

try

{

conn.Open();

MessageBox.Show(conn.State.ToString());

}

catch (Exception ex)

{

ShowErrorMessage(ex.Message.ToString());

}

finally

{

conn.Close();

}

二:通过System.Data.OracleClient(需要安装Oracle客户端不需配置tnsnames.ora)

1. 添加命名空间System.Data.OracleClient引用

2. using System.Data.OracleClient;

3.

string connString = "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)))";

OracleConnection conn = new OracleConnection(connString);

try

{

conn.Open();

MessageBox.Show(conn.State.ToString());

}

catch (Exception ex)

{

ShowErrorMessage(ex.Message.ToString());

}

finally

{

conn.Close();

}

三:通过System.Data.OleDb和Oracle公司的驱动

1. 添加命名空间System.Data.OracleClient引用

2. using System.Data.OleDb;

3.

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)))";

OleDbConnection conn = new OleDbConnection(connString);

try

{

conn.Open();

MessageBox.Show(conn.State.ToString());

}

catch (Exception ex)

{

ShowErrorMessage(ex.Message.ToString());

}

finally

{

conn.Close();

}

四:通过System.Data.OleDb和微软公司的Oracle驱动

1. 添加命名空间System.Data.OracleClient引用

2. using System.Data.OleDb;

3.

string connString = "Provider=MSDAORA.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)))";

OleDbConnection cnn = new OleDbConnection(connString);

try

{

conn.Open();

MessageBox.Show(conn.State.ToString());

}

catch (Exception ex)

{

ShowErrorMessage(ex.Message.ToString());

}

finally

{

conn.Close();

}

备注:

a.XP操作系统已经安装了微软公司的Oracle驱动C:\Program Files\Common Files\System\Ole DB\msdaora.dll

b.该驱动需要Oracle客户端的三个文件(oraocixe10.dll、oci.dll、ociw32.dll)放在System32下即可

五:使用ODP连接

1. 下载安装ODP.NET(http://www.oracle.com/technetwork/developer-tools/visual-studio/downloads/index.html)

2. 安装完全成后会产生一序列文件。

3. 找到这个安装目录,打开文件夹%ORACLE_HOME%\Network\Admin在这个下面建立一个tnsnames.ora的文件,其内容可以参考其下的Sample目录下面的配置

Oracle.RACE =

(DESCRIPTION=

(ADDRESS_LIST=

(ADDRESS=

(PROTOCOL=TCP)

(HOST=127.0.0.1)

(PORT=1521)

)

)

(CONNECT_DATA=

(SID=RACE)

(SERVER=DEDICATED)

)

)

Oracle.RACE为连接字符串名称,可以随便取。等号后面的字符串可以在Enterprise Manager Console工具中连接数据库后的TNS描述符中拷过来

4. 引用Oracle.DataAccess命名空间

5. using Oracle.DataAccess.Client;

6. 示例代码:

string connString = "DATA SOURCE=Oracle.RACE;PERSIST SECURITY INFO=True;USER ID=IFSAPP;password=IFSAPP";

OracleConnection conn = new OracleConnection(connString);

try

{

conn.Open();

OracleCommand cmd = new OracleCommand(cmdText,conn);

OracleDataReader reader = cmd.ExecuteReader();

this.DataGridView1.DataSource = reader;

this.DataGridView1.DataBind();

}

catch (Exception ex)

{

ShowErrorMessage(ex.Message.ToString());

}

finally

{

conn.Close();

}

六:使用第三方驱动

第三方驱动有 Devart,下载驱动 http://www.devart.com/dotconnect/oracle/,但是是商业版,需要购买许可或破解

连接格式 User ID=myUsername;Password=myPassword;Host=ora;Pooling=true;Min Pool Size=0;Max Pool Size=100;Connection Lifetime=0;

1. 引用Devart.Data.Oracle命名空间

2. using Devart.Data.Oracle;

3.

OracleConnection conn = new OracleConnection();

conn.ConnectionString = "";

conn.Unicode = true;

conn.UserId = "IFSAPP";

conn.Password = "IFSAPP";

conn.Port = 1521;

conn.Server = "127.0.0.1";

conn.Sid = "RACE";

try

{

conn.Open();

//execute queries, etc

}

catch (Exception ex)

{

ShowErrorMessage(ex.Message.ToString());

}

finally

{

conn.Close();

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: