明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

ASP.NET訪問(wèn)Oracle數(shù)據(jù)庫(kù)的方法

[摘要]引言Microsoft .NET Framework Data Provider for Oracle(以下簡(jiǎn)稱為.NET for Oracle)是一個(gè).NET Framework的組件。這個(gè)組件為我們使用.NET訪問(wèn)Oracle數(shù)據(jù)庫(kù)提供了極大的方便。那些使用.NET和Oracle的開(kāi)發(fā)人員,相...

引言

Microsoft .NET Framework Data Provider for Oracle(以下簡(jiǎn)稱為.NET for Oracle)是一個(gè).NET Framework的組件。這個(gè)組件為我們使用.NET訪問(wèn)Oracle數(shù)據(jù)庫(kù)提供了極大的方便。那些使用.NET和Oracle的開(kāi)發(fā)人員,相信會(huì)樂(lè)的手舞足蹈,因?yàn)樗麄冊(cè)僖膊槐厥褂媚莻(gè)并不十分“專業(yè)="的OLEDB來(lái)訪問(wèn)Oracle數(shù)據(jù)庫(kù)了。這個(gè)組件的設(shè)計(jì)非常類似.NET中內(nèi)置的Microsoft .NET Framework Data Provider for SQL Server和OLEDB。如果讀者非常熟悉這兩個(gè)內(nèi)置的組件,那么相信您學(xué)習(xí)這個(gè)組件也是輕車熟路的。

本文針對(duì)的讀者主要是那些考慮使用.NET技術(shù)訪問(wèn)Oracle數(shù)據(jù)庫(kù)的程序員而編寫(xiě),需要有一定的C#語(yǔ)言、ADO.NET技術(shù)和Oracle數(shù)據(jù)庫(kù)基礎(chǔ)知識(shí)。文中結(jié)合ASP.NET技術(shù)給出了相關(guān)示例以及具體的注釋。當(dāng)然,這并不意味著.NET for Oracle組件只能為編寫(xiě)ASP.NET程序提供服務(wù),同樣它還可以為使用.NET技術(shù)編寫(xiě)的Windows程序提供方便。

本文將簡(jiǎn)要介紹ASP.NET for Oracle的系統(tǒng)需求和安裝以及核心類,之后重點(diǎn)詳解使用此組件訪問(wèn)Oracle數(shù)據(jù)庫(kù)的方法。其中包括.NET for Oracle對(duì)于各種Oracle數(shù)據(jù)庫(kù)中的特殊數(shù)據(jù)類型的訪問(wèn)、各種核心類使用方法的介紹并且在文章的最后給出了示例等等。


--------------------------------------------------------------------------------

系統(tǒng)需求和安裝

在安裝.NET for Oracle之前,必須首先安裝.NET Framework version 1.0。同時(shí),還要確定安裝了數(shù)據(jù)訪問(wèn)組件(MDAC 2.6及其以上版本,推薦版本是2.7)。既然是要訪問(wèn)Oracle數(shù)據(jù)庫(kù)的數(shù)據(jù),那么還需要安裝Oracle 8i Release 3 (8.1.7) Client及其以上版本。目前Oracle9i已經(jīng)發(fā)布,作者本人安裝的是Oracle 9i,本文中所有的程序,都是在Oracle9i數(shù)據(jù)庫(kù)環(huán)境下編寫(xiě)和調(diào)試完成的。

組件的安裝非常方便,直接運(yùn)行oracle_net.msi。在安裝過(guò)程中無(wú)需任何設(shè)置,一路點(diǎn)擊“NEXT="完成安裝即可。默認(rèn)安裝將在C:\Program Files\ Microsoft.NET目錄下建立一個(gè)名為OracleClient.Net的文件夾,其中包含以下六個(gè)文件,具體的注釋如下表:

 

注意:Mtxoci8.dll文件并未安裝在默認(rèn)文件夾中,而是安裝在系統(tǒng)目錄中,例如:c:\Windows\System32目錄中。

對(duì)于開(kāi)發(fā)人員,其中至關(guān)重要的是System.Data.OracleClient.dll文件。這是.NET for Oracle組件的核心文件。使用時(shí),開(kāi)發(fā)人員可以通過(guò)安裝oracle_net.msi來(lái)使用.NET for Oracle組件,這時(shí)系統(tǒng)會(huì)將此組件作為一個(gè)系統(tǒng)默認(rèn)的組件來(lái)使用,就好像是我們所熟悉的System.Data.SqlClient和System.Data.OleDb組件一樣。但是,需要注意的一點(diǎn)是:當(dāng)開(kāi)發(fā)人員完成了程序之后分發(fā)給用戶使用時(shí),出于對(duì)于軟件易用性的考慮,我們是不希望當(dāng)用戶使用此軟件之前,還要如同開(kāi)發(fā)人員一樣安裝oracle_net.msi。這時(shí)開(kāi)發(fā)人員可以在發(fā)布之前,將System.Data.OracleClient.dll文件復(fù)制到軟件的bin目錄下。這樣用戶就可無(wú)需安裝oracle_net.msi而正常的使用軟件所提供的功能了。(這種方法限于開(kāi)發(fā)的程序不涉及分布式事務(wù))


--------------------------------------------------------------------------------

核心類介紹

.NET for Oracle組件中用于組織類和其他類型的名字空間是System.Data.OracleClient。在此名字空間中,主要包含四個(gè)核心類,它們分別是:OracleConnection、OracleCommand、OracleDataReader、OracleDataAdapter。如果開(kāi)發(fā)人員很了解ADO.NET技術(shù),那么對(duì)于這四個(gè)類的使用將是耳熟能詳?shù)摹_@些內(nèi)容非常簡(jiǎn)單,其具體使用方法幾乎和SqlConnection、SqlCommand、SqlDataReader、SqlDataAdapter是一模一樣的。這里就不再詳細(xì)說(shuō)明,讀者將在后文中通過(guò)示例了解使用這些類的有關(guān)情況,這里只給出下表以供讀者簡(jiǎn)要了解。

 

--------------------------------------------------------------------------------

舉例說(shuō)明

下面是一個(gè)使用.NET for Oracle組件操縱Oracle數(shù)據(jù)庫(kù)的例子。在寫(xiě)程序之前,先要在Oracle數(shù)據(jù)庫(kù)中建立一個(gè)表,并且加入一行數(shù)據(jù)。使用下面的語(yǔ)句。

建立一個(gè)名為OracleTypesTable的表
"create table OracleTypesTable (MyVarchar2 varchar2(3000),MyNumber number(28,4)
Primary key ,MyDate date,MyRaw RAW(255))";
插入一行數(shù)據(jù)
"insert into OracleTypesTable values ('test',4,to_date('2000-01-11
12:54:01','yyyy-mm-dd hh24:mi:ss'),'0001020304')";
下面的程序就是要通過(guò).NET for Oracle組件來(lái)訪問(wèn)Oracle數(shù)據(jù)庫(kù),并且顯示出這行數(shù)據(jù)。在程序中請(qǐng)注意前文中所說(shuō)明的類,并且聯(lián)想.NET中關(guān)于數(shù)據(jù)處理類的使用方法。

1. using System;
2.using System.Web;
3.using System.Web.UI;
4.using System.Web.UI.HtmlControls;
5.using System.Web.UI.WebControls;
6.using System.Data;
7.using System.Data.OracleClient;

8.public class pic2:Page {
9. public Label message;
10. public void Page_Load(Object sender,EventArgs e)
11. {
//設(shè)置連接字符串
12. string connstring="Data Source=eims;user=zbmis;password=zbmis;";
//實(shí)例化OracleConnection對(duì)象
13. OracleConnection conn=new OracleConnection(connstring);

14. try
15. {
16. conn.Open();
//實(shí)例化OracleCommand對(duì)象
17. OracleCommand cmd=conn.CreateCommand();

18. cmd.CommandText="select * from zbmis.OracleTypesTable";
19. OracleDataReader oracledatareader1=cmd.ExecuteReader();
//讀取數(shù)據(jù)
20. while (oracledatareader1.Read()) {
//讀取并顯示第一行第一列的數(shù)據(jù)
21. OracleString oraclestring1=oracledatareader1.GetOracleString(0);
22. Response.Write("OracleString " +oraclestring1.ToString());

//讀取并顯示第一行第二列的數(shù)據(jù)
23. OracleNumber oraclenumber1 =oracledatareader1.GetOracleNumber(1);
24. Response.Write("OracleNumber "+oraclenumber1.ToString());

//讀取并顯示第一行第三列的數(shù)據(jù)
25. OracleDateTime oracledatetime1=oracledatareader1.GetOracleDateTime(2);
26. Response.Write("OracleDateTime " +oracledatetime1.ToString());

//讀取并顯示第一行第四列的數(shù)據(jù)
27. OracleBinary oraclebinary1=oracledatareader1.GetOracleBinary(3);
28. if(oraclebinary1.IsNull==false)
29. {
30. foreach(byte b in oraclebinary1.Value)
31. {
32. Response.Write("byte " +b.ToString());
33. }
34. }
35. }
//釋放資源
36. oracledatareader1.Close();
37. }
38. catch(Exception ee)
39. {
//異常處理
40. message.Text=ee.Message;
41. }
42. finally
43. {
//關(guān)閉連接
44. conn.Close();
45. }
46. }
47.}
如果您對(duì)于.NET中數(shù)據(jù)操作的內(nèi)容很熟悉,那么相信上面的程序是完全看得懂的。所以在這里分析上面代碼意義不是很大。

請(qǐng)那些既使用.NET又使用Oracle的讀者記。.NET for Oracle組件的設(shè)計(jì)非常類似.NET中內(nèi)置的Data Provider for SQL Server和OLEDB。