ASP.NET訪問Oracle資料庫的方法

來源:互聯網
上載者:User
asp.net|oracle|訪問|資料|資料庫 引言

Microsoft .NET Framework Data Provider for Oracle(以下簡稱為.NET for Oracle)是一個.NET Framework的組件。這個組件為我們使用.NET訪問Oracle資料庫提供了極大的方便。那些使用.NET和Oracle的開發人員,相信會樂的手舞足蹈,因為他們再也不必使用那個並不十分“專業="的OLEDB來訪問Oracle資料庫了。這個組件的設計非常類似.NET中內建的Microsoft .NET Framework Data Provider for SQL Server和OLEDB。如果讀者非常熟悉這兩個內建的組件,那麼相信您學習這個組件也是輕車熟路的。

本文針對的讀者主要是那些考慮使用.NET技術訪問Oracle資料庫的程式員而編寫,需要有一定的C#語言、ADO.NET技術和Oracle資料庫基礎知識。文中結合ASP.NET技術給出了相關樣本以及具體的注釋。當然,這並不意味著.NET for Oracle組件只能為編寫ASP.NET程式提供服務,同樣它還可以為使用.NET技術編寫的Windows程式提供方便。

本文將簡要介紹ASP.NET for Oracle的系統需求和安裝以及核心類,之後重點詳解使用此組件訪問Oracle資料庫的方法。其中包括.NET for Oracle對於各種Oracle資料庫中的特殊資料類型的訪問、各種核心類使用方法的介紹並且在文章的最後給出了樣本等等。

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

系統需求和安裝

在安裝.NET for Oracle之前,必須首先安裝.NET Framework version 1.0。同時,還要確定安裝了資料訪問組件(MDAC 2.6及其以上版本,推薦版本是2.7)。既然是要訪問Oracle資料庫的資料,那麼還需要安裝Oracle 8i Release 3 (8.1.7) Client及其以上版本。目前Oracle9i已經發布,作者本人安裝的是Oracle 9i,本文中所有的程式,都是在Oracle9i資料庫環境下編寫和調試完成的。

組件的安裝非常方便,直接運行oracle_net.msi。在安裝過程中無需任何設定,一路點擊“NEXT="完成安裝即可。預設安裝將在C:\Program Files\ Microsoft.NET目錄下建立一個名為OracleClient.Net的檔案夾,其中包含以下六個檔案,具體的注釋如下表:

注意:Mtxoci8.dll檔案並未安裝在預設資料夾中,而是安裝在系統目錄中,例如:c:\Windows\System32目錄中。

對於開發人員,其中至關重要的是System.Data.OracleClient.dll檔案。這是.NET for Oracle組件的核心檔案。使用時,開發人員可以通過安裝oracle_net.msi來使用.NET for Oracle組件,這時系統會將此組件作為一個系統預設的組件來使用,就好像是我們所熟悉的System.Data.SqlClient和System.Data.OleDb組件一樣。但是,需要注意的一點是:當開發人員完成了程式之後分發給使用者使用時,出於對於軟體易用性的考慮,我們是不希望當使用者使用此軟體之前,還要如同開發人員一樣安裝oracle_net.msi。這時開發人員可以在發布之前,將System.Data.OracleClient.dll檔案複製到軟體的bin目錄下。這樣使用者就可無需安裝oracle_net.msi而正常的使用軟體所提供的功能了。(這種方法限於開發的程式不涉及分散式交易)

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

核心類介紹

.NET for Oracle組件中用於組織類和其他類型的名字空間是System.Data.OracleClient。在此名字空間中,主要包含四個核心類,它們分別是:OracleConnection、OracleCommand、OracleDataReader、OracleDataAdapter。如果開發人員很瞭解ADO.NET技術,那麼對於這四個類的使用將是耳熟能詳的。這些內容非常簡單,其具體使用方法幾乎和SqlConnection、SqlCommand、SqlDataReader、SqlDataAdapter是一模一樣的。這裡就不再詳細說明,讀者將在後文中通過樣本瞭解使用這些類的有關情況,這裡只給出下表以供讀者簡要瞭解。

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

舉例說明

下面是一個使用.NET for Oracle組件操縱Oracle資料庫的例子。在寫程式之前,先要在Oracle資料庫中建立一個表,並且加入一行資料。使用下面的語句。

建立一個名為OracleTypesTable的表
"create table OracleTypesTable (MyVarchar2 varchar2(3000),MyNumber number(28,4)
Primary key ,MyDate date,MyRaw RAW(255))";
插入一行資料
"insert into OracleTypesTable values ('test',4,to_date('2000-01-11
12:54:01','yyyy-mm-dd hh24:mi:ss'),'0001020304')";
下面的程式就是要通過.NET for Oracle組件來訪問Oracle資料庫,並且顯示出這行資料。在程式中請注意前文中所說明的類,並且聯想.NET中關於資料處理類的使用方法。

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. {
//設定連接字串
12. string connstring="Data Source=eims;user=zbmis;password=zbmis;";
//執行個體化OracleConnection對象
13. OracleConnection conn=new OracleConnection(connstring);

14. try
15. {
16. conn.Open();
//執行個體化OracleCommand對象
17. OracleCommand cmd=conn.CreateCommand();

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

//讀取並顯示第一行第二列的資料
23. OracleNumber oraclenumber1 =oracledatareader1.GetOracleNumber(1);
24. Response.Write("OracleNumber "+oraclenumber1.ToString());

//讀取並顯示第一行第三列的資料
25. OracleDateTime oracledatetime1=oracledatareader1.GetOracleDateTime(2);
26. Response.Write("OracleDateTime " +oracledatetime1.ToString());

//讀取並顯示第一行第四列的資料
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. {
//關閉串連
44. conn.Close();
45. }
46. }
47.}
如果您對於.NET中資料操作的內容很熟悉,那麼相信上面的程式是完全看得懂的。所以在這裡分析上面代碼意義不是很大。

請那些既使用.NET又使用Oracle的讀者記住:.NET for Oracle組件的設計非常類似.NET中內建的Data Provider for SQL Server和OLEDB




相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。