亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ASP.NET訪問Oracle數據庫的方法

2019-11-18 19:41:44
字體:
來源:轉載
供稿:網友

引言

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。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品福利在线| 午夜精品福利视频| 久久久爽爽爽美女图片| 97婷婷大伊香蕉精品视频| www高清在线视频日韩欧美| 久久精品久久久久久| 亚洲欧美国内爽妇网| 在线观看欧美日韩国产| 午夜欧美不卡精品aaaaa| 欧美一级电影免费在线观看| 国产日韩精品综合网站| 91精品国产综合久久男男| 欧美理论在线观看| 国产在线一区二区三区| 日韩欧美亚洲范冰冰与中字| 久久韩剧网电视剧| 欧美与欧洲交xxxx免费观看| 97精品在线观看| 色综合久久88色综合天天看泰| 欧美视频中文字幕在线| 亚洲精品成人久久电影| 久久精品福利视频| 国产玖玖精品视频| 色婷婷综合久久久久| 亚洲人成自拍网站| 欧美亚洲视频在线观看| 一个人看的www久久| 98视频在线噜噜噜国产| 日本午夜精品理论片a级appf发布| 91精品国产91久久久久久最新| 国产精品久久久久久av福利软件| 91系列在线播放| 欧美一区二区大胆人体摄影专业网站| 国产欧美精品日韩精品| 国产精品狠色婷| 日韩亚洲欧美成人| 欧美视频在线观看免费| 日韩精品免费看| 国产主播喷水一区二区| 亚洲乱码一区av黑人高潮| 国产精品欧美亚洲777777| 色爱精品视频一区| 国产成人精品日本亚洲专区61| 久久天天躁狠狠躁夜夜爽蜜月| 日韩最新在线视频| 国产美女高潮久久白浆| 在线观看中文字幕亚洲| 91av在线视频观看| 亚洲在线视频福利| 国产精品入口免费视频一| 久久亚洲综合国产精品99麻豆精品福利| 欧美视频第一页| 亚洲一区二区三区777| 91av在线播放视频| 国产激情999| 国产精品视频网站| 欧美精品18videos性欧| 在线亚洲欧美视频| 欧美成人精品三级在线观看| 日韩a**站在线观看| 欧美成人三级视频网站| 日韩av影院在线观看| 精品香蕉在线观看视频一| 久久成人一区二区| 亚洲日韩欧美视频| 欧美猛交ⅹxxx乱大交视频| 91国内产香蕉| 最近2019中文字幕第三页视频| 中文字幕亚洲天堂| 久久视频免费在线播放| 日韩欧美国产网站| 久久久精品一区二区三区| 91免费电影网站| 国产精品日韩欧美| 欧美激情极品视频| 成人黄色网免费| 国产精品成人v| 精品国产一区二区三区久久狼黑人| 高清欧美一区二区三区| 精品久久久久久久久久久久久久| 国产一区私人高清影院| 亚洲综合大片69999| 国产999精品| 欧美日韩国产精品一区二区三区四区| 欧美多人爱爱视频网站| 成人福利网站在线观看| 国产精品狠色婷| 亚洲免费高清视频| 色婷婷综合久久久久| 精品中文字幕在线2019| 一区二区三区高清国产| 日韩欧美在线播放| 国产成人亚洲综合91精品| 2019亚洲男人天堂| 欧美一级淫片丝袜脚交| 亚洲精品在线91| 日韩视频第一页| 精品国内产的精品视频在线观看| xvideos成人免费中文版| 亚洲新声在线观看| 久久久国产精品免费| 欧美黑人巨大xxx极品| 亚洲免费视频一区二区| 国产欧美在线观看| 久久人人爽人人爽人人片av高请| 久久久亚洲天堂| 亚洲最新在线视频| 粉嫩av一区二区三区免费野| 91免费精品国偷自产在线| 亚洲欧美另类国产| 国产免费成人av| 欧美成人精品一区二区三区| 色悠久久久久综合先锋影音下载| 北条麻妃在线一区二区| 欧美精品生活片| 亚洲精品v天堂中文字幕| 欧美激情区在线播放| 国产又爽又黄的激情精品视频| 精品久久久久久国产| 日韩欧美黄色动漫| 国产精品爽爽爽| 91久久综合亚洲鲁鲁五月天| 国产精品欧美激情在线播放| 欧美一区二区影院| 欧美精品999| 国产一区视频在线| 色av中文字幕一区| 欧美怡红院视频一区二区三区| 97久久久免费福利网址| 91色琪琪电影亚洲精品久久| 久久成人18免费网站| 国产精品自产拍在线观看| 欧美影院在线播放| 国产日韩欧美在线看| 成人激情电影一区二区| 最新91在线视频| 欧美丰满老妇厨房牲生活| 5566成人精品视频免费| 欧美日产国产成人免费图片| 久久久久久91香蕉国产| 日韩a**站在线观看| 在线播放国产一区中文字幕剧情欧美| 国内精久久久久久久久久人| 国产suv精品一区二区三区88区| 中文字幕在线观看日韩| 国产精品一区二区三区免费视频| 91精品久久久久久| 精品亚洲一区二区三区在线播放| 久久香蕉国产线看观看av| 中文字幕在线观看亚洲| 色哟哟亚洲精品一区二区| 久久久国产精彩视频美女艺术照福利| 亚洲激情视频在线| 69av在线播放| 亚洲视频一区二区| 国产精品视频yy9099| 欧美日韩一区二区精品| 久久国产精品久久久| 亚洲欧洲自拍偷拍| 法国裸体一区二区| 精品视频久久久久久久| 亚洲午夜色婷婷在线| 欧美成人精品在线| 国产精品黄页免费高清在线观看|