ASP.NET訪問Oracle數據庫的方法
引言
Microsoft.NETFrameworkDataProviderforOracle(以下簡稱為.NETforOracle)是一個.NETFramework的組件。這個組件為我們使用.NET訪問Oracle數據庫提供了極大的方便。那些使用.NET和Oracle的開發人員,相信會樂的手舞足蹈,因為他們再也不必使用那個並不十分“專業="的OLEDB來訪問Oracle數據庫了。這個組件的設計非常類似.NET中內置的Microsoft.NETFrameworkDataProviderforSQLServer和OLEDB。如果讀者非常熟悉這兩個內置的組件,那麼相信您學習這個組件也是輕車熟路的。
本文針對的讀者主要是那些考慮使用.NET技術訪問Oracle數據庫的程序員而編寫,需要有一定的C#語言、ADO.NET技術和Oracle數據庫基礎知識。文中結合ASP.NET技術給出了相關示例以及具體的注釋。當然,這並不意味著.NETforOracle組件隻能為編寫ASP.NET程序提供服務,同樣它還可以為使用.NET技術編寫的Windows程序提供方便。
本文將簡要介紹ASP.NETforOracle的係統需求和安裝以及核心類,之後重點詳解使用此組件訪問Oracle數據庫的方法。其中包括.NETforOracle對於各種Oracle數據庫中的特殊數據類型的訪問、各種核心類使用方法的介紹並且在文章的最後給出了示例等等。
--------------------------------------------------------------------------------
係統需求和安裝
在安裝.NETforOracle之前,必須首先安裝.NETFrameworkversion1.0。同時,還要確定安裝了數據訪問組件(MDAC2.6及其以上版本,推薦版本是2.7)。既然是要訪問Oracle數據庫的數據,那麼還需要安裝Oracle8iRelease3(8.1.7)Client及其以上版本。目前Oracle9i已經發布,作者本人安裝的是Oracle9i,本文中所有的程序,都是在Oracle9i數據庫環境下編寫和調試完成的。
組件的安裝非常方便,直接運行oracle_net.msi。在安裝過程中無需任何設置,一路點擊“NEXT="完成安裝即可。默認安裝將在C:/ProgramFiles/Microsoft.NET目錄下建立一個名為OracleClient.Net的文件夾,其中包含以下六個文件,具體的注釋如下表:
注意:Mtxoci8.dll文件並未安裝在默認文件夾中,而是安裝在係統目錄中,例如:c:/Windows/System32目錄中。
對於開發人員,其中至關重要的是System.Data.OracleClient.dll文件。這是.NETforOracle組件的核心文件。使用時,開發人員可以通過安裝oracle_net.msi來使用.NETforOracle組件,這時係統會將此組件作為一個係統默認的組件來使用,就好像是我們所熟悉的System.Data.SqlClient和System.Data.OleDb組件一樣。但是,需要注意的一點是:當開發人員完成了程序之後分發給用戶使用時,出於對於軟件易用性的考慮,我們是不希望當用戶使用此軟件之前,還要如同開發人員一樣安裝oracle_net.msi。這時開發人員可以在發布之前,將System.Data.OracleClient.dll文件複製到軟件的bin目錄下。這樣用戶就可無需安裝oracle_net.msi而正常的使用軟件所提供的功能了。(這種方法限於開發的程序不涉及分布式事務)
--------------------------------------------------------------------------------
核心類介紹
.NETforOracle組件中用於組織類和其他類型的名字空間是System.Data.OracleClient。在此名字空間中,主要包含四個核心類,它們分別是:OracleConnection、OracleCommand、OracleDataReader、OracleDataAdapter。如果開發人員很了解ADO.NET技術,那麼對於這四個類的使用將是耳熟能詳的。這些內容非常簡單,其具體使用方法幾乎和SqlConnection、SqlCommand、SqlDataReader、SqlDataAdapter是一模一樣的。這裏就不再詳細說明,讀者將在後文中通過示例了解使用這些類的有關情況,這裏隻給出下表以供讀者簡要了解。
--------------------------------------------------------------------------------
舉例說明
下麵是一個使用.NETforOracle組件操縱Oracle數據庫的例子。在寫程序之前,先要在Oracle數據庫中建立一個表,並且加入一行數據。使用下麵的語句。
建立一個名為OracleTypesTable的表
"createtableOracleTypesTable(MyVarchar2varchar2(3000),MyNumbernumber(28,4)
Primarykey,MyDatedate,MyRawRAW(255))";
插入一行數據
"insertintoOracleTypesTablevalues('test',4,to_date('2000-01-11
12:54:01','yyyy-mm-ddhh24:mi:ss'),'0001020304')";
下麵的程序就是要通過.NETforOracle組件來訪問Oracle數據庫,並且顯示出這行數據。在程序中請注意前文中所說明的類,並且聯想.NET中關於數據處理類的使用方法。
1.usingSystem;
2.usingSystem.Web;
3.usingSystem.Web.UI;
4.usingSystem.Web.UI.HtmlControls;
5.usingSystem.Web.UI.WebControls;
6.usingSystem.Data;
7.usingSystem.Data.OracleClient;
8.publicclasspic2:Page{
9.publicLabelmessage;
10.publicvoidPage_Load(Objectsender,EventArgse)
11.{
//設置連接字符串
12.stringconnstring="DataSource=eims;user=zbmis;password=zbmis;";
//實例化OracleConnection對象
13.OracleConnectionconn=newOracleConnection(connstring);
14.try
15.{
16.conn.Open();
//實例化OracleCommand對象
17.OracleCommandcmd=conn.CreateCommand();
18.cmd.CommandText="select*fromzbmis.OracleTypesTable";
19.OracleDataReaderoracledatareader1=cmd.ExecuteReader();
//讀取數據
20.while(oracledatareader1.Read()){
//讀取並顯示第一行第一列的數據
21.OracleStringoraclestring1=oracledatareader1.GetOracleString(0);
22.Response.Write("OracleString"+oraclestring1.ToString());
//讀取並顯示第一行第二列的數據
23.OracleNumberoraclenumber1=oracledatareader1.GetOracleNumber(1);
24.Response.Write("OracleNumber"+oraclenumber1.ToString());
//讀取並顯示第一行第三列的數據
25.OracleDateTimeoracledatetime1=oracledatareader1.GetOracleDateTime(2);
26.Response.Write("OracleDateTime"+oracledatetime1.ToString());
//讀取並顯示第一行第四列的數據
27.OracleBinaryoraclebinary1=oracledatareader1.GetOracleBinary(3);
28.if(oraclebinary1.IsNull==false)
29.{
30.foreach(bytebinoraclebinary1.Value)
31.{
32.Response.Write("byte"+b.ToString());
33.}
34.}
35.}
//釋放資源
36.oracledatareader1.Close();
37.}
38.catch(Exceptionee)
39.{
//異常處理
40.message.Text=ee.Message;
41.}
42.finally
43.{
//關閉連接
44.conn.Close();
45.}
46.}
47.}
如果您對於.NET中數據操作的內容很熟悉,那麼相信上麵的程序是完全看得懂的。所以在這裏分析上麵代碼意義不是很大。
請那些既使用.NET又使用Oracle的讀者記住:.NETforOracle組件的設計非常類似.NET中內置的DataProviderforSQLServer和OLEDB。
最後更新:2017-04-02 00:06:33