成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

趣味深談ADO.NET數(shù)據(jù)訪問技術(shù)

開發(fā) 后端
這里就ADO.NET數(shù)據(jù)訪問避免Database-Agnostic形式的編程,在ADO.NET中,你可以用OleDbConnection類創(chuàng)建到一個數(shù)據(jù)庫的連接,這個類可以讓你訪問各種數(shù)據(jù)源。

經(jīng)過長時間學(xué)習(xí)ADO.NET,于是和大家分享一下ADO.NET數(shù)據(jù)訪問,看完本文你肯定有不少收獲,希望本文能教會你更多東西。ADO.NET提供了一個統(tǒng)一的編程模式和一組公用的類來進行任何類型的數(shù)據(jù)訪問,而不管你用何種語言來開發(fā)代碼。ADO.NET是全新的,但又與ADO盡可能保持一致,它使編程模式從一個客戶端 /服務(wù)器、基于連接的模式轉(zhuǎn)變到了一個新的模式,這個新模式可以讓斷開的前端下載記錄、離線工作、然后重新連接來提交變化。ADO.NET是 WinForms應(yīng)用程序、ASP.NET應(yīng)用程序和Web services的一個共有的特點。其功能可以跨LAN和Internet連接來實現(xiàn),可以在有狀態(tài)(stateful)和無狀態(tài)(stateless)情況下實現(xiàn)。

這就意味著,作為一個共有的技術(shù),ADO.NET的對象在所有可能的環(huán)境中并不是同等強大的。用ADO.NET為一個富客戶端(rich client)構(gòu)建一個數(shù)據(jù)層同為一個客戶端通常是共享的和重要的實體(如Web服務(wù)器)的Web應(yīng)用程序構(gòu)建一個數(shù)據(jù)層并不一樣。

#T#如果你從前是個ADO開發(fā)人員,現(xiàn)在已經(jīng)用ADO.NET了,那么你可能把數(shù)據(jù)訪問看做是一個***的對象,如Recordset。我們很自然地會將舊的對象模式同新的對象模式匹配起來,并將現(xiàn)有的方法用于.NET應(yīng)用程序。然而,在ADO環(huán)境中的某些好的方法在轉(zhuǎn)換到ADO.NET環(huán)境時就可能并不強大了。而且,看起來很微不足道的ADO.NET對象模式的復(fù)雜性可能會導(dǎo)致很糟糕的編程情況、不理想的代碼、甚至是功能不能實現(xiàn)。我將講述在 ADO.NET編程中可能會給你帶來麻煩的10個方面,并提供技巧和解決方法來避免它們。

ADO.NET數(shù)據(jù)訪問避免Database-Agnostic形式的編程

ADO.NET數(shù)據(jù)訪問是強類型的,就是說在任何時候你都必須了解你正在處理的是什么數(shù)據(jù)源(data source)。相反,在ADO中,你可以編寫數(shù)據(jù)訪問代碼(它們充分利用了OLE DB提供者的通用模式),并將基本的數(shù)據(jù)源只看做是個參數(shù)。ADO對象模式提供了唯一的連接和命令對象,它們隱藏了基本的DBMS的特征。一旦你在 Connection對象上設(shè)置了Provider屬性,那么為SQL Server或Oracle創(chuàng)建一個命令對象就需要同樣的代碼。許多開發(fā)人員都通過該功能來使用生產(chǎn)環(huán)境外的Access數(shù)據(jù)庫,以便很快地測試或演示應(yīng)用程序。

在ADO.NET中是不能這么做的,因為在ADO.NET中,至少連接對象必須是特定于數(shù)據(jù)源的。你不能以一種間接或通用的方式來創(chuàng)建連接,除非你決定運用ADO的數(shù)據(jù)訪問技術(shù)——OLE DB。在ADO.NET中,你可以用OleDbConnection類創(chuàng)建到一個數(shù)據(jù)庫的連接,這個類可以讓你訪問各種數(shù)據(jù)源。在.NET托管環(huán)境中運用 System.Data.OleDb名字空間中的類并不特別有效,因為它們是用OLE DB來訪問數(shù)據(jù)的。你只能用OLE DB來訪問那些沒有.NET數(shù)據(jù)提供者的數(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)  

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

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

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

2009-11-11 14:19:39

ADO.NET數(shù)據(jù)列

2009-12-31 09:54:04

ADO.NET數(shù)據(jù)訪問

2009-06-18 09:56:44

ADO.NET對象模型

2009-11-11 13:59:15

ADO.NET與ADO

2009-12-30 15:21:55

ADO.NET訪問

2009-12-22 16:23:26

ADO.NET訪問

2009-12-23 17:54:01

ADO.NET 2.0

2009-11-13 09:24:17

2009-11-12 15:00:03

ADO.NET實體數(shù)據(jù)

2009-12-21 16:53:06

ADO.NET使用說明

2009-11-12 10:32:47

ADO.NET技術(shù)

2009-12-31 15:39:46

ADO.NET訪問數(shù)據(jù)

2009-12-24 10:37:03

ADO.NET訪問數(shù)據(jù)

2009-12-23 15:53:36

ADO.NET訪問數(shù)據(jù)

2009-12-29 15:44:11

ADO.NET檢索技術(shù)

2009-11-13 10:01:50

ADO.NET CAS

2009-12-28 14:54:48

ADO.NET語句

2009-12-28 15:38:36

ADO.NET分頁

2009-12-22 17:43:26

ADO.Net技術(shù)

2009-08-13 11:22:59

LINQ和ADO.NE
點贊
收藏

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

主站蜘蛛池模板: 日韩一级免费 | 涩爱av一区二区三区 | 九九久久精品 | 国产超碰人人爽人人做人人爱 | 国产蜜臀97一区二区三区 | 日韩av一区二区在线观看 | 日韩欧美一区在线 | 日韩和的一区二区 | 午夜在线视频一区二区三区 | 中文字字幕一区二区三区四区五区 | 亚洲国产视频一区 | 久草在线中文888 | 在线免费观看亚洲 | 日韩视频 中文字幕 | 国产一区不卡在线观看 | 国产精品久久久久久久久免费软件 | 一区二区伦理电影 | 色视频成人在线观看免 | 亚洲人成在线观看 | 中文字幕成人av | 大象一区 | 国产精品美女久久久久久免费 | 国产精品久久久久久福利一牛影视 | 欧美日韩高清在线一区 | 国产精品高潮呻吟久久 | 日本三级做a全过程在线观看 | 天堂av资源| 91免费看片 | 正在播放国产精品 | caoporn国产精品免费公开 | 9久久| 天堂网av在线 | a级大片 | 99福利视频 | 欧美成年网站 | 精品欧美一区免费观看α√ | 国产欧美精品区一区二区三区 | 久久专区 | 欧洲精品久久久久毛片完整版 | 日韩影院在线 | 国产乱码一二三区精品 |