日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
ADO.NET編程技巧揭秘

#T#經(jīng)過長(zhǎng)時(shí)間學(xué)習(xí)ADO.NET編程,總結(jié)了一些經(jīng)驗(yàn),在這里把我知道的ADO.NET編程技巧介紹給大家,希望本文能教會(huì)你更多東西。ADO.NET提供了一個(gè)統(tǒng)一的編程模式和一組公用的類來進(jìn)行任何類型的數(shù)據(jù)訪問,而不管你用何種語言來開發(fā)代碼。ADO.NET是全新的,但又與ADO盡可能保持一致,它使編程模式從一個(gè)客戶端/服務(wù)器、基于連接的模式轉(zhuǎn)變到了一個(gè)新的模式,這個(gè)新模式可以讓斷開的前端下載記錄、離線工作、然后重新連接來提交變化。ADO.NET是WinForms應(yīng)用程序、ASP.NET應(yīng)用程序和Web services的一個(gè)共有的特點(diǎn)。其功能可以跨LAN和Internet連接來實(shí)現(xiàn),可以在有狀態(tài)(stateful)和無狀態(tài)(stateless)情況下實(shí)現(xiàn)。
 
這就意味著,作為一個(gè)共有的技術(shù),ADO.NET的對(duì)象在所有可能的環(huán)境中并不是同等強(qiáng)大的。用ADO.NET為一個(gè)富客戶端(rich client)構(gòu)建一個(gè)數(shù)據(jù)層同為一個(gè)客戶端通常是共享的和重要的實(shí)體(如Web服務(wù)器)的Web應(yīng)用程序構(gòu)建一個(gè)數(shù)據(jù)層并不一樣。
 
如果你從前是個(gè)ADO開發(fā)人員,現(xiàn)在已經(jīng)用ADO.NET了,那么你可能把數(shù)據(jù)訪問看做是一個(gè)萬能的對(duì)象,如Recordset.我們很自然地會(huì)將舊的對(duì)象模式同新的對(duì)象模式匹配起來,并將現(xiàn)有的方法用于。NET應(yīng)用程序。然而,在ADO環(huán)境中的某些好的方法在轉(zhuǎn)換到ADO.NET環(huán)境時(shí)就可能并不強(qiáng)大了。而且,看起來很微不足道的ADO.NET對(duì)象模式的復(fù)雜性可能會(huì)導(dǎo)致很糟糕的編程情況、不理想的代碼、甚至是功能不能實(shí)現(xiàn)。我將講述在ADO.NET 編程中可能會(huì)給你帶來麻煩的10個(gè)方面,并提供技巧和解決方法來避免它們。
 
ADO.NET編程技巧之避免Database-Agnostic形式的編程

創(chuàng)新互聯(lián)擁有10多年成都網(wǎng)站建設(shè)工作經(jīng)驗(yàn),為各大企業(yè)提供網(wǎng)站設(shè)計(jì)制作、成都做網(wǎng)站服務(wù),對(duì)于網(wǎng)頁設(shè)計(jì)、PC網(wǎng)站建設(shè)(電腦版網(wǎng)站建設(shè))、app軟件開發(fā)公司、wap網(wǎng)站建設(shè)(手機(jī)版網(wǎng)站建設(shè))、程序開發(fā)、網(wǎng)站優(yōu)化(SEO優(yōu)化)、微網(wǎng)站、申請(qǐng)域名等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們?cè)诨ヂ?lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)積累了很多網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)絡(luò)營銷經(jīng)驗(yàn),集策劃、開發(fā)、設(shè)計(jì)、營銷、管理等網(wǎng)站化運(yùn)作于一體,具備承接各種規(guī)模類型的網(wǎng)站建設(shè)項(xiàng)目的能力。

ADO.NET中的數(shù)據(jù)訪問是強(qiáng)類型的,就是說在任何時(shí)候你都必須了解你正在處理的是什么數(shù)據(jù)源(data source)。相反,在ADO中,你可以編寫數(shù)據(jù)訪問代碼(它們充分利用了OLE DB提供者的通用模式),并將基本的數(shù)據(jù)源只看做是個(gè)參數(shù)。ADO對(duì)象模式提供了唯一的連接和命令對(duì)象,它們隱藏了基本的DBMS的特征。一旦你在 Connection對(duì)象上設(shè)置了Provider屬性,那么為SQL Server或Oracle創(chuàng)建一個(gè)命令對(duì)象就需要同樣的代碼。許多開發(fā)人員都通過該功能來使用生產(chǎn)環(huán)境外的Access數(shù)據(jù)庫,以便很快地測(cè)試或演示應(yīng)用程序。
 
在ADO.NET中是不能這么做的,因?yàn)樵贏DO.NET中,至少連接對(duì)象必須是特定于數(shù)據(jù)源的。你不能以一種間接或通用的方式來創(chuàng)建連接,除非你決定運(yùn)用ADO的數(shù)據(jù)訪問技術(shù)——OLE DB.在ADO.NET中,你可以用OleDbConnection類創(chuàng)建到一個(gè)數(shù)據(jù)庫的連接,這個(gè)類可以讓你訪問各種數(shù)據(jù)源。在。NET托管環(huán)境中運(yùn)用 System.Data.OleDb名字空間中的類并不特別有效,因?yàn)樗鼈兪怯肙LE DB來訪問數(shù)據(jù)的。你只能用OLE DB來訪問那些沒有。NET數(shù)據(jù)提供者的數(shù)據(jù)源。
 
如果你的應(yīng)用程序必須訪問全異的數(shù)據(jù)源(而且你知道可能涉及什么數(shù)據(jù)源——一個(gè)合理的假設(shè)),那么你可以創(chuàng)建一個(gè)集中的factory類,它返回一個(gè)連接對(duì)象,并通過一個(gè)通用的接口(IDbConnection接口)來管理這個(gè)連接對(duì)象。Factory類在內(nèi)部運(yùn)用應(yīng)用程序參數(shù)來決定使用什么.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的方式來創(chuàng)建和執(zhí)行一個(gè)命令了,而不管使用的數(shù)據(jù)源是什么。你可以使用CreateCommand方法并通過IDbCommand接口來引用命令。然后,你可以用IDbCommand接口上的 ExecuteReader方法或ExecuteNonQuery方法來執(zhí)行命令。如果你用ExecuteReader,你就可以得到一個(gè)data reader并可以用IDataReader接口來對(duì)它進(jìn)行一般的訪問了。
 
你不能用一個(gè)通用的數(shù)據(jù)庫編程模式來填充一個(gè) DataSet對(duì)象。實(shí)際上,你不能像創(chuàng)建一個(gè)命令那樣以一種間接的方式來創(chuàng)建data adapter對(duì)象。原因就是,在有些情況下,data adapter不同于命令對(duì)象,它可以在內(nèi)部隱含地創(chuàng)建一個(gè)連接。然而,它必須以一種強(qiáng)類型的方式工作,而且必須知道基本的數(shù)據(jù)庫服務(wù)器是什么,上述是一個(gè)關(guān)于避免Database-Agnostic形式ADO.NET編程技巧。


本文名稱:ADO.NET編程技巧揭秘
標(biāo)題來源:http://www.5511xx.com/article/dpdiidp.html