自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

ADO.NET學(xué)習(xí)避免Database-Agnostic形式編程

開(kāi)發(fā) 后端
在ADO.NET學(xué)習(xí)中你可能遇到Database-Agnostic形式的編程,這里教你怎樣避免這種形式編程方法,希望對(duì)大家有幫助。

我們?cè)贏DO.NET學(xué)習(xí)中應(yīng)該總結(jié)編程技巧,這讓使我們的編程速度提高,這里就我在ADO.NET學(xué)習(xí)總結(jié)的關(guān)于避免Database-Agnostic形式的編程和大家分析一下。在ADO.NET學(xué)習(xí)中數(shù)據(jù)訪問(wèn)是強(qiáng)類(lèi)型的,就是說(shuō)在任何時(shí)候你都必須了解你正在處理的是什么數(shù)據(jù)源(data source)。相反,在ADO中,你可以編寫(xiě)數(shù)據(jù)訪問(wèn)代碼(它們充分利用了OLE DB提供者的通用模式),并將基本的數(shù)據(jù)源只看做是個(gè)參數(shù)。

ADO對(duì)象模式提供了***的連接和命令對(duì)象,它們隱藏了基本的DBMS的特征。一旦你在 Connection對(duì)象上設(shè)置了Provider屬性,那么為SQL Server或Oracle創(chuàng)建一個(gè)命令對(duì)象就需要同樣的代碼。許多開(kāi)發(fā)人員都通過(guò)該功能來(lái)使用生產(chǎn)環(huán)境外的Access數(shù)據(jù)庫(kù),以便很快地測(cè)試或演示應(yīng)用程序。

#T#在ADO.NET中是不能這么做的,因?yàn)樵贏DO.NET中,至少連接對(duì)象必須是特定于數(shù)據(jù)源的。你不能以一種間接或通用的方式來(lái)創(chuàng)建連接,除非你決定運(yùn)用ADO的數(shù)據(jù)訪問(wèn)技術(shù)——OLE DB。在ADO.NET中,你可以用OleDbConnection類(lèi)創(chuàng)建到一個(gè)數(shù)據(jù)庫(kù)的連接,這個(gè)類(lèi)可以讓你訪問(wèn)各種數(shù)據(jù)源。在.NET托管環(huán)境中運(yùn)用 System.Data.OleDb名字空間中的類(lèi)并不特別有效,因?yàn)樗鼈兪怯肙LE DB來(lái)訪問(wèn)數(shù)據(jù)的。你只能用OLE DB來(lái)訪問(wèn)那些沒(méi)有.NET數(shù)據(jù)提供者的數(shù)據(jù)源。

如果你的應(yīng)用程序必須訪問(wèn)全異的數(shù)據(jù)源(而且你知道可能涉及什么數(shù)據(jù)源——一個(gè)合理的假設(shè)),那么你可以創(chuàng)建一個(gè)集中的factory類(lèi),它返回一個(gè)連接對(duì)象,并通過(guò)一個(gè)通用的接口(IDbConnection接口)來(lái)管理這個(gè)連接對(duì)象。Factory類(lèi)在內(nèi)部運(yùn)用應(yīng)用程序參數(shù)來(lái)決定使用什么.NET數(shù)據(jù)提供者:'

  1. Create the connection  
  2. Dim factory As New MyAppConnectionFactory  
  3. Dim conn As IDbConnection  
  4. conn = factory.CreateConnection(connString)  
  5.  
  6. ' Create the command  
  7. Dim cmd As IDbCommand = conn.CreateCommand(query)  

一旦你得到了一個(gè)連接對(duì)象,你就可以以database-agnostic的方式來(lái)創(chuàng)建和執(zhí)行一個(gè)命令了,而不管使用的數(shù)據(jù)源是什么。你可以使用CreateCommand方法并通過(guò)IDbCommand接口來(lái)引用命令。然后,你可以用IDbCommand接口上的ExecuteReader方法或ExecuteNonQuery方法來(lái)執(zhí)行命令。如果你用ExecuteReader,你就可以得到一個(gè)data reader并可以用IDataReader接口來(lái)對(duì)它進(jìn)行一般的訪問(wèn)了。

你不能用一個(gè)通用的數(shù)據(jù)庫(kù)編程模式來(lái)填充一個(gè)DataSet對(duì)象。實(shí)際上,你不能像創(chuàng)建一個(gè)命令那樣以一種間接的方式來(lái)創(chuàng)建data adapter對(duì)象。原因就是,在有些情況下,data adapter不同于命令對(duì)象,它可以在內(nèi)部隱含地創(chuàng)建一個(gè)連接。然而,它必須以一種強(qiáng)類(lèi)型的方式工作,而且必須知道基本的數(shù)據(jù)庫(kù)服務(wù)器是什么。

責(zé)任編輯:田樹(shù) 來(lái)源: 博客
相關(guān)推薦

2009-11-03 17:25:59

ADO.NET編程技巧

2009-12-21 14:55:49

ADO.NET屬性

2009-12-22 16:42:57

ADO.NET研究

2009-12-24 09:26:01

ADO.Net Tea

2009-12-28 13:47:31

ADO.NET對(duì)象

2009-12-22 17:43:26

ADO.Net技術(shù)

2009-11-13 09:45:54

ADO.NET程序集

2009-12-22 09:50:23

ADO.NET學(xué)習(xí)

2009-12-28 15:11:36

ADO.NET專(zhuān)家

2009-12-22 14:46:09

ADO.NET Ent

2009-12-28 17:09:34

ADO.NET實(shí)例

2009-12-24 11:12:29

ADO.Net技術(shù)

2009-12-23 17:21:31

ADO.NET團(tuán)隊(duì)

2009-12-23 10:10:59

ADO.NET編程

2010-01-04 11:02:06

ADO.NET組件

2011-05-20 11:31:07

ADO.NET

2009-09-04 14:52:03

ADO.NET Ent

2009-11-03 16:37:10

2009-09-14 13:37:25

LINQ ADO.NE

2009-12-22 14:05:33

ADO.NET代碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)