<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="zh">
	<id>https://arolstar52-zhtest.hf.space/index.php?action=history&amp;feed=atom&amp;title=ADO.NET</id>
	<title>ADO.NET - 版本历史</title>
	<link rel="self" type="application/atom+xml" href="https://arolstar52-zhtest.hf.space/index.php?action=history&amp;feed=atom&amp;title=ADO.NET"/>
	<link rel="alternate" type="text/html" href="https://arolstar52-zhtest.hf.space/index.php?title=ADO.NET&amp;action=history"/>
	<updated>2026-06-30T16:53:39Z</updated>
	<subtitle>在这个wiki上该页的修订历史</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://arolstar52-zhtest.hf.space/index.php?title=ADO.NET&amp;diff=121963&amp;oldid=prev</id>
		<title>imported&gt;Shawwww：​使用DisamAssist清理消歧义链接：LINQ（链接至语言集成查询）。</title>
		<link rel="alternate" type="text/html" href="https://arolstar52-zhtest.hf.space/index.php?title=ADO.NET&amp;diff=121963&amp;oldid=prev"/>
		<updated>2024-09-10T16:07:21Z</updated>

		<summary type="html">&lt;p&gt;使用&lt;a href=&quot;/index.php?title=User:%E6%9A%81%E6%9C%88%E5%87%9B%E5%A5%88/DisamAssist&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;User:暁月凛奈/DisamAssist（页面不存在）&quot;&gt;DisamAssist&lt;/a&gt;清理&lt;a href=&quot;https://en.wikipedia.org/wiki/%E6%B6%88%E6%AD%A7%E4%B9%89&quot; class=&quot;extiw&quot; title=&quot;wikipedia:消歧义&quot;&gt;消歧义&lt;/a&gt;链接：&lt;a href=&quot;/wiki/LINQ&quot; title=&quot;LINQ&quot;&gt;LINQ&lt;/a&gt;（链接至&lt;a href=&quot;/wiki/%E8%AF%AD%E8%A8%80%E9%9B%86%E6%88%90%E6%9F%A5%E8%AF%A2&quot; title=&quot;语言集成查询&quot;&gt;语言集成查询&lt;/a&gt;）。&lt;/p&gt;
&lt;p&gt;&lt;b&gt;新页面&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{noteTA&lt;br /&gt;
|G1=IT&lt;br /&gt;
|G2=Windows&lt;br /&gt;
|1=zh-hans:数据;zh-hant:資料;&lt;br /&gt;
}}&lt;br /&gt;
{{Infobox software&lt;br /&gt;
| operating system = [[Microsoft Windows]]&lt;br /&gt;
| genre = [[软件框架]]&lt;br /&gt;
| license = [[Microsoft|MS-EULA]]、[[Base Class Library|BCL]]（在[[微软参考授权]]下发布）&lt;br /&gt;
| website = [http://msdn2.microsoft.com/en-us/library/aa286484.aspx ADO.NET Overview on MSDN]&lt;br /&gt;
| Nonprofit =&lt;br /&gt;
}}&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;ADO.NET&amp;#039;&amp;#039;&amp;#039;是微軟在[[.NET Framework]]中負責[[資料存取]]的類別庫集，它是使用在[[COM]]時代奠基的[[OLE DB]]技術以及[[.NET Framework]]的類別庫和程式語言來發展的，它可以讓.NET上的任何程式語言能夠連接並存取[[關聯式資料庫]]與非資料庫型資料來源（例如XML，Excel或是文字檔資料），或是獨立出來作為處理應用程式資料的類別物件，其在.NET Framework中的地位是舉足輕重，許多人將ADO.NET視為 ActiveX Data Objects (ADO) 的下一個版本，但其實它是一個全新的架構、產品與概念。&lt;br /&gt;
&lt;br /&gt;
ADO.NET类封装在System.Data.dll中，并且与System.Xml.dll中的XML类集成。&lt;br /&gt;
&lt;br /&gt;
== 历史 ==&lt;br /&gt;
=== 發展緣起 ===&lt;br /&gt;
&lt;br /&gt;
在1990年代初期，微軟已經開發了許多的資料存取方式，像是[[ODBC]]架構、和[[Microsoft Access]]資料庫交互使用的[[Microsoft Data Access Object|DAO]]物件、可以跨越網路存取資料的{{tsl|en|Remote Data Objects|Remote Data Object|RDO}}以及讓DAO元件可以存取ODBC資料來源的[[ODBCDirect]]技術等等，技術雖然多，但是卻又各自為政，而且每個技術的重疊性也很高（像是ODBC有Microsoft Access的驅動程式）；RDO雖然可跨網路，但是ODBC的驅動程式中也有提供跨網路的功能（像是[[SQL Server]]和[[Oracle]]驅動程式），如此琳琅滿目重疊性又高的技術群，讓企業與開發人員在選擇、學習與應用上產生了很多的困難。&lt;br /&gt;
&lt;br /&gt;
1996年，適逢[[COM]]的出现，微軟將資料存取的核心開始改寫為以COM為基础的[[OLE DB]]，並且在它上面建立一個新的统一的資料存取的高层对象模型－[[ADO]]。ADO推出後順利的取代了DAO和RDO，成為在[[Windows NT 4.0]]和[[Windows 2000]]作業系統上開發資料庫應用程式的首選。它將[[OLE DB]]的物件模型进一步简化；由資料庫廠商开发满足[[OLE DB]]接口的資料提供者（data provider，這個模式在此時奠基），而ADO本身則是與資料來源無關（data source independent）的对象结构，讓它迅速的獲得了使用[[Active Server Pages|ASP]]、[[Visual Basic]]、[[COM]]的開發人員的青睞。它能夠順利取代DAO與RDO，要關鍵在于ADO的与数据库服务器端/客户端的特性无关，这使得ADO通用性极好。然而ADO本身的架構仍然有缺陷（尤其是在開發網路應用程式時，最好的例子就是Recordset無法離線），這也是微軟為何不在[[.NET Framework]]中繼續使用ADO的主要原因。&lt;br /&gt;
&lt;br /&gt;
1998年時，微軟提出了一個下一代的應用程式開發框架（Application Framework）的計畫&amp;lt;ref&amp;gt;{{Cite web |url=http://www.winsupersite.com/showcase/win2k_complus.asp |title=COM+, A Windows 2000 technology showcase |accessdate=2009-01-11 |archive-date=2000-08-16 |archive-url=https://web.archive.org/web/20000816180623/http://www.winsupersite.com/showcase/win2k_complus.asp |dead-url=yes }}&amp;lt;/ref&amp;gt;，計畫中包含了：&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;ASP+&amp;#039;&amp;#039;&amp;#039;：改良與重新設計ASP技術，強化它的Web應用程式發展能力。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;Storage+&amp;#039;&amp;#039;&amp;#039;：發展新的資料庫與物件導向之檔案系統結構（用於SQL Server 8.0（即後來的[[SQL Server 2000]]）與[[NTFS]]），以及發展新一代的資料存取元件，並改良ADO本身的缺陷，讓它更能夠成為應用程式資料存取的核心功能。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;COM+&amp;#039;&amp;#039;&amp;#039;：改良COM和[[Microsoft Transaction Server|MTS]]，成為企業級應用程式開發的基礎元件。&lt;br /&gt;
&lt;br /&gt;
ADO+即為Storage+的一支。&lt;br /&gt;
&lt;br /&gt;
=== ADO.NET的前身：ADO+ ===&lt;br /&gt;
1998年起，因為[[Web-based Application|Web應用程式]]的竄起，大大改變了許多應用程式的設計方式，傳統的資料庫連線保存設計法無法適用於此類應用程式，這讓ADO應用程式遇到了很大的瓶頸，也讓微軟開始思考讓資料集（Resultset，在ADO中稱為Recordset）能夠離線化的能力，以及能在用戶端建立一個小型資料庫的概念&amp;lt;ref&amp;gt;{{Cite web |url=http://www.developerfusion.com/article/56/ado/ |title=ADO+ |accessdate=2009-01-11 |archive-date=2009-12-03 |archive-url=https://web.archive.org/web/20091203094831/http://www.developerfusion.com/article/56/ado |dead-url=no }}&amp;lt;/ref&amp;gt;{{NoteTag|此概念的原型為In-Memory Database，又稱IMDB，可在記憶體中運行的資料庫，然而以當時的環境（2000年初，記憶體尚未跌到目前的價格水準），以及技術不成熟的情況下，這項技術在Windows 2000 RC2時被抽離。}}，這個概念就是ADO.NET中離線型資料模型（disconnected data model）的基礎，而在ADO的使用情形來看，資料庫連線以及資源耗用的情形較嚴重（像是Server-side cursor或是Recordset.Open會保持連線狀態），在ADO.NET中也改良了這些物件，構成了能夠減少資料庫連線和資源使用量的功能。[[XML]]的使用也是這個版本的重要發展之一。&lt;br /&gt;
&lt;br /&gt;
2000年，微軟的Microsoft .NET計畫開始成形，許多的微軟產品都冠上.NET的標籤，ADO+也不例外，改名為ADO.NET{{NoteTag|有相同遭遇的還有ASP+（改名為ASP.NET）。}}，並包裝到.NET Framework類別庫中，成為.NET平台中唯一的資料存取元件。&lt;br /&gt;
&lt;br /&gt;
== 架構 ==&lt;br /&gt;
&lt;br /&gt;
ADO.NET由連線資料來源（connected data source）以及離線資料模型（disconnected data model）兩個部份構成&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/zh-tw/library/27y4ybxw.aspx |title=ADO.NET架構 |accessdate=2009-01-11 |archive-date=2010-01-19 |archive-url=https://web.archive.org/web/20100119081600/http://msdn.microsoft.com/zh-tw/library/27y4ybxw.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;，這兩個部份是相輔相成的。&lt;br /&gt;
=== 連線資料來源 ===&lt;br /&gt;
若沒辦法連線到資料庫，則無法被稱為資料存取元件。連線資料來源便是用來連接資料庫（或是具有OLE DB資料來源提供者）的物件類別&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/zh-tw/library/ms254937.aspx |title=擷取和修改ADO.NET中的資料 |accessdate=2009-01-11 |archive-date=2008-12-02 |archive-url=https://web.archive.org/web/20081202141158/http://msdn.microsoft.com/zh-tw/library/ms254937.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;，由下列接口構成：&lt;br /&gt;
&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDbConnection&amp;#039;&amp;#039;&amp;#039;，負責與資料庫的連線管理，包含連線字串（connection string），連線的開關，資料庫交易的啟始與連線錯誤的處理，所有的ADO.NET資料提供者都要實作此介面。&lt;br /&gt;
** &amp;lt;code&amp;gt;Open()/Close()&amp;lt;/code&amp;gt;：開啟與關閉資料庫連線。&lt;br /&gt;
** &amp;lt;code&amp;gt;BeginTransaction()&amp;lt;/code&amp;gt;：啟動資料庫交易，並回傳一個&amp;lt;code&amp;gt;IDbTransaction&amp;lt;/code&amp;gt;物件，以控制交易的結果。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDbCommand&amp;#039;&amp;#039;&amp;#039;，負責執行資料庫指令（在大多數的案例中都是[[SQL]]指令），並傳回由資料庫中擷取的結果集，或是執行不回傳結果集的資料庫指令。&lt;br /&gt;
** &amp;lt;code&amp;gt;ExecuteNonQuery()&amp;lt;/code&amp;gt;：執行不回傳結果集的資料庫指令，像是&amp;lt;code&amp;gt;INSERT&amp;lt;/code&amp;gt;、&amp;lt;code&amp;gt;UPDATE&amp;lt;/code&amp;gt;與&amp;lt;code&amp;gt;DELETE&amp;lt;/code&amp;gt;指令，返回值为该命令所影响的行数。 对于其他所有类型的语句，返回值 为 -1。&lt;br /&gt;
** &amp;lt;code&amp;gt;ExecuteScalar()&amp;lt;/code&amp;gt;：執行指令並回傳第一列第一行中的值（object类型）。当没有数据时，ExcuteScalar方法返回System.DBNull。&lt;br /&gt;
** &amp;lt;code&amp;gt;ExecuteReader()&amp;lt;/code&amp;gt;：執行指令並回傳IDataReader物件，以讀取資料集中的資料。&lt;br /&gt;
** &amp;lt;code&amp;gt;BeginExecuteNonQuery&amp;lt;/code&amp;gt;：开始执行异步查询&lt;br /&gt;
** &amp;lt;code&amp;gt;EndExecuteNonQuery&amp;lt;/code&amp;gt;: 结束执行异步查询&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDataParameter&amp;#039;&amp;#039;&amp;#039;，負責裝載資料庫指令所需要的參數資料，在使用[[參數化查詢]]時會經常使用。 对于不同的数据源来说，占位符不同。SQLServer数据源用@parametername格式来命名参数，OleDb以及Odbc数据源均用问号（?）来标识参数位置，而Oracle则以:parmname格式使用命名参数。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDbTransaction&amp;#039;&amp;#039;&amp;#039;，負責裝載資料庫交易所需的控制物件，以執行交易的認可（commit）或撤銷（rollback）的工作。&lt;br /&gt;
** &amp;lt;code&amp;gt;Commit()&amp;lt;/code&amp;gt;：認可資料庫交易。&lt;br /&gt;
** &amp;lt;code&amp;gt;Rollback()&amp;lt;/code&amp;gt;：撤銷資料庫交易。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDbDataAdapter&amp;#039;&amp;#039;&amp;#039;，負責將來自於IDbCommand執行取得的結果集，裝載到離線型資料集（DataSet）或是離線型資料表（DataTable）中。&lt;br /&gt;
** &amp;lt;code&amp;gt;Fill()&amp;lt;/code&amp;gt;：將資料填入離線型資料物件。&lt;br /&gt;
** &amp;lt;code&amp;gt;Update()&amp;lt;/code&amp;gt;：將變更過的離線型資料物件中的資料寫回資料庫。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDataReader&amp;#039;&amp;#039;&amp;#039;，建立一個只可向前讀取游標（forward-only）的資料讀取器工具，以逐列讀取方式存取資料，&amp;lt;code&amp;gt;IDbDataAdapter&amp;lt;/code&amp;gt;內部也是由它來讀取資料。&lt;br /&gt;
** &amp;lt;code&amp;gt;Read()&amp;lt;/code&amp;gt;：第一次调用Read()方法获取第一行数据，并将游标指向下一行数据。当再次调用该方法时候，将读取下一行数据。当检测到不再有数据行时，Read()方法将返回&amp;lt;code&amp;gt;false&amp;lt;/code&amp;gt;。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;IDataRecord&amp;#039;&amp;#039;&amp;#039;，在&amp;lt;code&amp;gt;IDataReader&amp;lt;/code&amp;gt;讀取資料後實際裝載資料列的物件，提供方法來讀取資料行中的資料，以及轉換成.NET Framework原生型別的工具。&lt;br /&gt;
** &amp;lt;code&amp;gt;GetOrdinal()&amp;lt;/code&amp;gt;：取得指定資料行的欄位索引值。&lt;br /&gt;
** &amp;lt;code&amp;gt;IsDBNull()&amp;lt;/code&amp;gt;：判斷指定欄位的資料是否為[[空值|NULL值]]。&lt;br /&gt;
使用連線資料來源需要由開發人員自我管理連線，並且直接操作資料存取的相關細節，但它的優點是速度快，而且可以自訂整個資料存取流程的邏輯。&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== ADO.NET資料提供者(Data Provider) ===&lt;br /&gt;
&lt;br /&gt;
在.NET Framework中，ADO.NET預設提供了四種資料來源：&lt;br /&gt;
&lt;br /&gt;
* SQL Server：由System.Data.SqlClient提供原生資料來源，是微軟官方建議存取SQL Server時建議使用的資料提供者。以Sql為字首的類別群&lt;br /&gt;
* OLE DB Data Source：由System.Data.OleDb提供支援，可適用於OLE DB Provider for ODBC以外的OLE DB資料提供者。以OleDb為字首的類別群。支持本地事务和分布式事务。 对于分布式事务，默认情况下，用于 OLE DB 的 .NET Framework 数据提供程序会自动登记在事务中，并自动从 Windows 2000 组件服务获取事务详细信息。&lt;br /&gt;
* Oracle：由System.Data.OracleClient提供支援，但使用者的電腦必須安裝Oracle Client 8.1.7或更新版本才行（.NET Framework 1.1開始支援）。以Oracle為字首的類別群。必须同时引用 System.Data和 System.Data.OracleClient。&lt;br /&gt;
* ODBC：補OLE DB Provider for ODBC的支援，由System.Data.Odbc提供支援（.NET Framework 1.1開始支援）。以Odbc為字首的類別群&lt;br /&gt;
* EntityClient实体数据模型(EDM)应用程序的数据访问。使用 System.Data.EntityClient 命名空间。&lt;br /&gt;
 &lt;br /&gt;
其他廠商亦為不同的資料庫提供資料來源：&lt;br /&gt;
&lt;br /&gt;
*[http://www.datadirect.com/products/net/index.ssp DataDirect Technologies]{{Wayback|url=http://www.datadirect.com/products/net/index.ssp |date=20060421221256 }}發行100%列管提供源，支援主流企業數據庫（Oracle, Sybase, DB2, SQL Server, Progress RDBMS）&lt;br /&gt;
*[https://archive.today/20040820120501/http://uda.openlinksw.com/ado.net/ OpenLink Software]給大量的客戶指定數據庫發行提供源，包括到其他資料存取機構的橋接提供源，並可以在視窗下微軟自己或者[[Mono]]的CLR實做下支援。&lt;br /&gt;
*[http://dev.mysql.com/downloads/connector/net/5.1.html MySQL]{{Wayback|url=http://dev.mysql.com/downloads/connector/net/5.1.html |date=20080731003221 }}為本身的MySQL Database Server提供了ADO.NET的原生資料提供者。&lt;br /&gt;
*[https://web.archive.org/web/20080516201531/http://www.oracle.com/technology/global/cn/tech/windows/odpnet/index.html Oracle]自行開發的.NET Data Provider。&lt;br /&gt;
&lt;br /&gt;
对每种Data Provider，ADO.NET要实现下述对象结构：&lt;br /&gt;
*Connection 对象提供与数据源的连接。&lt;br /&gt;
*Command对象使您能够访问用于返回数据、修改数据、运行存储过程以及发送或检索参数信息的数据库命令。&lt;br /&gt;
*DataReader 对象从数据源中提供快速的，只读的数据流。&lt;br /&gt;
*DataAdapter 对象提供连接 DataSet 对象和数据源的桥梁。DataAdapter 使用 Command 对象在数据源中执行 SQL 命令，以便将数据加载到 DataSet 中，并使对 DataSet 中数据的更改与数据源保持一致。&lt;br /&gt;
*Parameter 对象用于参数化查询。&lt;br /&gt;
例如，对于SQL Server数据源：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;C#&amp;quot;&amp;gt;&lt;br /&gt;
strSQL = &amp;quot;SELECT * FROM users WHERE Name = @Name and Password = @Password&amp;quot;;&lt;br /&gt;
SqlParamter[] paras = new SqlParamter[]{//参数数组&lt;br /&gt;
     new SqlParamter(&amp;quot;@Name&amp;quot;,SqlDBType.Varchar,50)&lt;br /&gt;
     new SqlParamter(&amp;quot;@Password&amp;quot;,SqlDBType.Varchar,50)};&lt;br /&gt;
paras[0].value = userName;//绑定用户名&lt;br /&gt;
paras[1].value = password;//绑定用户密码&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
*ConnectionStringBuilder：提供一种用于创建和管理由 Connection 对象使用的连接字符串的内容的简单方法。 所有 ConnectionStringBuilder 对象的基类均为 DbConnectionStringBuilder 类。 &lt;br /&gt;
*CommandBuilder ：自动生成 DataAdapter 的命令属性或从存储过程中派生参数信息，并填充 Command 对象的 Parameters 集合。 所有 CommandBuilder 对象的基类均为 DbCommandBuilder 类。&lt;br /&gt;
&lt;br /&gt;
=== 離線資料模型 ===&lt;br /&gt;
&lt;br /&gt;
離線資料模型是微軟為了改良ADO在網路應用程式中的缺陷所設計的，同時它也是[[微軟元件服務|COM+]]中，IMDB技術的設計概念的實作品，但它並沒有完整的IMDB功能，像是交易處理（transaction processing），但它仍不失為一個能在離線狀態下處理資料的好幫手，它也可以透過連線資料來源物件，支援將離線資料存回資料庫的能力&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/zh-tw/library/ss7fbaez.aspx |title=DataSet、DataTable及DataView（ADO.NET） |accessdate=2009-01-11 |archive-date=2008-09-26 |archive-url=https://web.archive.org/web/20080926023805/http://msdn.microsoft.com/zh-tw/library/ss7fbaez.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;。離線資料模型由下列物件組成：&lt;br /&gt;
&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;DataSet&amp;#039;&amp;#039;&amp;#039;，離線型資料模型的核心之一，可將它當成一個離線型的資料庫，它可以內含許多個DataTable，並且利用關聯與限制方式來設定資料的完整性，它本身也提供了可以和XML交互作業的支援。&lt;br /&gt;
** &amp;lt;code&amp;gt;ReadXml()/WriteXml()&amp;lt;/code&amp;gt;：以DataSet的結構讀寫XML。&lt;br /&gt;
** &amp;lt;code&amp;gt;ReadXmlSchema()/WriteXmlSchema()&amp;lt;/code&amp;gt;：以DataSet的結構讀寫[[XML Schema]]。&lt;br /&gt;
** &amp;lt;code&amp;gt;GetXml()/GetXmlSchema()&amp;lt;/code&amp;gt;：取得DataSet內容的XML或XML Schema。&lt;br /&gt;
** &amp;lt;code&amp;gt;Merge()&amp;lt;/code&amp;gt;：合併兩個DataSet。&lt;br /&gt;
** &amp;lt;code&amp;gt;Load()&amp;lt;/code&amp;gt;：自&amp;lt;code&amp;gt;IDataReader&amp;lt;/code&amp;gt;載入資料到DataSet。&lt;br /&gt;
** &amp;lt;code&amp;gt;AcceptChanges()&amp;lt;/code&amp;gt;：將修改過的資料列的修改旗標改為&amp;lt;code&amp;gt;Unchanged&amp;lt;/code&amp;gt;。&lt;br /&gt;
** &amp;lt;code&amp;gt;GetChanges()&amp;lt;/code&amp;gt;：將修改過的資料列以DataRow陣列方式傳回。&lt;br /&gt;
** &amp;lt;code&amp;gt;RejectChanges()&amp;lt;/code&amp;gt;：撤銷所有資料的修改。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;DataTable&amp;#039;&amp;#039;&amp;#039;，離線型資料模型的核心之一，可將它當成一個離線型的資料表，是儲存資料的收納器。&lt;br /&gt;
** &amp;lt;code&amp;gt;Copy()&amp;lt;/code&amp;gt;：將DataTable複製出一個副本，包含結構與資料。&lt;br /&gt;
** &amp;lt;code&amp;gt;Merge()&amp;lt;/code&amp;gt;：將兩個DataTable合併。&lt;br /&gt;
** &amp;lt;code&amp;gt;Select()&amp;lt;/code&amp;gt;：以指定的特殊查詢語法，傳回符合條件的DataRow陣列。&lt;br /&gt;
** &amp;lt;code&amp;gt;Compute()&amp;lt;/code&amp;gt;：以指定的彙總語法，傳回彙總的結果。&lt;br /&gt;
** &amp;lt;code&amp;gt;GetErrors()&amp;lt;/code&amp;gt;：傳回有錯誤的DataRow陣列。&lt;br /&gt;
** &amp;lt;code&amp;gt;HasErrors&amp;lt;/code&amp;gt;：判斷DataTable中的DataRow有沒有含有錯誤的DataRow。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;DataRow&amp;#039;&amp;#039;&amp;#039;，表示表格中的資料列，與資料欄組合成資料儲存的單元。&lt;br /&gt;
** &amp;lt;code&amp;gt;IsNull()&amp;lt;/code&amp;gt;：判斷指定的欄位是否為NULL值。&lt;br /&gt;
** &amp;lt;code&amp;gt;ItemArray&amp;lt;/code&amp;gt;：將DataRow中的資料轉換成陣列。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;DataColumn&amp;#039;&amp;#039;&amp;#039;，表示表格中的欄位。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;DataView&amp;#039;&amp;#039;&amp;#039;，展示資料的輔助元件，類似於資料庫中的[[視圖|檢視表]]，並可設定過濾條件與排序條件。&lt;br /&gt;
** &amp;lt;code&amp;gt;Filter&amp;lt;/code&amp;gt;：設定DataView的過濾條件。&lt;br /&gt;
** &amp;lt;code&amp;gt;Sort&amp;lt;/code&amp;gt;：設定DataView的排序條件。&lt;br /&gt;
** &amp;lt;code&amp;gt;ToTable()&amp;lt;/code&amp;gt;：將套用過濾與排序後的內容轉換為DataTable物件。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;DataRelation&amp;#039;&amp;#039;&amp;#039;，可在DataTable之間設定欄位間的關聯。&lt;br /&gt;
* &amp;#039;&amp;#039;&amp;#039;Constraint&amp;#039;&amp;#039;&amp;#039;，設定欄位的條件約束，例如&amp;lt;code&amp;gt;ForeignKeyConstraint&amp;lt;/code&amp;gt;為外部鍵限制，而&amp;lt;code&amp;gt;UniqueConstraint&amp;lt;/code&amp;gt;則確保了欄位中的值都是唯一的。&lt;br /&gt;
&lt;br /&gt;
DataSet和DataTable除了資料庫的處理以外，也經常被用來管理應用程式中的資料，並且由於它可以儲存在XML中的特性，也讓它可以用來儲存需要保存的應用程式資訊。DataSet中可包含DataRelation对象，用于建构表之间的约束关系。&lt;br /&gt;
&lt;br /&gt;
== 工廠方法 ==&lt;br /&gt;
&lt;br /&gt;
在.NET Framework 1.x的時代，ADO.NET不同的來源有不同的類別搭配（前面已述及），但是若想要在不同的資料來源間搭配，那麼勢必要產生很多的變數來存放不同的資料物件，因此微軟在.NET Framework 2.0中提供了一個&amp;lt;code&amp;gt;System.Data.Common&amp;lt;/code&amp;gt;命名空間，其中有各種必要物件的共用方法（例如連線是&amp;lt;code&amp;gt;DbConnection&amp;lt;/code&amp;gt;，命令是&amp;lt;code&amp;gt;DbCommand&amp;lt;/code&amp;gt;，讀取器是&amp;lt;code&amp;gt;DbDataReader&amp;lt;/code&amp;gt;，資料配接器是&amp;lt;code&amp;gt;DbDataAdapter&amp;lt;/code&amp;gt;等），以及&amp;lt;code&amp;gt;DbProviderFactory&amp;lt;/code&amp;gt;物件，用來總管資料存取的物件。&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;DbProviderFactories&amp;lt;/code&amp;gt;則是電腦中所有提供者的總管，開發人員可用&amp;lt;code&amp;gt;DbProviderFactories.GetFactoryClasses()&amp;lt;/code&amp;gt;取得各個提供者的Invariant Name，再於呼叫&amp;lt;code&amp;gt;DbProviderFactories.GetFactory()&amp;lt;/code&amp;gt;時傳入指定提供者的Invariant Name即可取得&amp;lt;code&amp;gt;DbProviderFactory&amp;lt;/code&amp;gt;，再利用下列方法取得共用物件：&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;DbProviderFactory.CreateConnection()&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;DbProviderFactory.CreateCommand()&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;DbProviderFactory.CreateParameter()&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;DbProviderFactory.CreateDataAdapter()&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
// This example assumes a reference to System.Data.Common.&lt;br /&gt;
static DataTable GetProviderFactoryClasses()&lt;br /&gt;
{&lt;br /&gt;
    // Retrieve the installed providers and factories.&lt;br /&gt;
    DataTable table = DbProviderFactories.GetFactoryClasses();&lt;br /&gt;
&lt;br /&gt;
    // Display each row and column value.&lt;br /&gt;
    foreach(DataRow row in table.Rows)&lt;br /&gt;
    {&lt;br /&gt;
        foreach(DataColumn column in table.Columns)&lt;br /&gt;
        {&lt;br /&gt;
            Console.WriteLine(row[column]);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    return table;&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== XML的整合 ==&lt;br /&gt;
&lt;br /&gt;
XML在ADO.NET中扮演了相當重要的地位，DataSet和DataTable都可以轉換成XML或和XML之間交換資料，在DataTable的內部資料的變更記錄，可以被輸出到一個XML的格式，用來識別變更的情形，這個格式稱為DiffGram，而且它可以直接讀入DataTable之中（使用DataTable.ReadXml（）並用XmlReadMode.DiffGram當參數）。一個典型的DiffGram如下：&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;xml&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;diffgr:diffgram xmlns:msdata=&amp;quot;urn:schemas-microsoft-com:xml-msdata&amp;quot; xmlns:diffgr=&amp;quot;urn:schemas-microsoft-com:xml-diffgram-v1&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;CustomerDataSet&amp;gt;&lt;br /&gt;
    &amp;lt;Customers diffgr:id=&amp;quot;Customers1&amp;quot; msdata:rowOrder=&amp;quot;0&amp;quot; diffgr:hasChanges=&amp;quot;modified&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;CustomerID&amp;gt;ALFKI&amp;lt;/CustomerID&amp;gt;&lt;br /&gt;
      &amp;lt;CompanyName&amp;gt;New Company&amp;lt;/CompanyName&amp;gt;&lt;br /&gt;
    &amp;lt;/Customers&amp;gt;&lt;br /&gt;
    &amp;lt;Customers diffgr:id=&amp;quot;Customers2&amp;quot; msdata:rowOrder=&amp;quot;1&amp;quot; diffgram:hasErrors=&amp;quot;true&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;CustomerID&amp;gt;ANATR&amp;lt;/CustomerID&amp;gt;&lt;br /&gt;
      &amp;lt;CompanyName&amp;gt;Ana Trujillo Emparedados y Helados&amp;lt;/CompanyName&amp;gt;&lt;br /&gt;
    &amp;lt;/Customers&amp;gt;&lt;br /&gt;
    &amp;lt;Customers diffgr:id=&amp;quot;Customers3&amp;quot; msdata:rowOrder=&amp;quot;2&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;CustomerID&amp;gt;ANTON&amp;lt;/CustomerID&amp;gt;&lt;br /&gt;
      &amp;lt;CompanyName&amp;gt;Antonio Moreno Taquera&amp;lt;/CompanyName&amp;gt;&lt;br /&gt;
    &amp;lt;/Customers&amp;gt;&lt;br /&gt;
    &amp;lt;Customers diffgr:id=&amp;quot;Customers4&amp;quot; msdata:rowOrder=&amp;quot;3&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;CustomerID&amp;gt;AROUT&amp;lt;/CustomerID&amp;gt;&lt;br /&gt;
      &amp;lt;CompanyName&amp;gt;Around the Horn&amp;lt;/CompanyName&amp;gt;&lt;br /&gt;
    &amp;lt;/Customers&amp;gt;&lt;br /&gt;
  &amp;lt;/CustomerDataSet&amp;gt;&lt;br /&gt;
  &amp;lt;diffgr:before&amp;gt;&lt;br /&gt;
    &amp;lt;Customers diffgr:id=&amp;quot;Customers1&amp;quot; msdata:rowOrder=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;CustomerID&amp;gt;ALFKI&amp;lt;/CustomerID&amp;gt;&lt;br /&gt;
      &amp;lt;CompanyName&amp;gt;Alfreds Futterkiste&amp;lt;/CompanyName&amp;gt;&lt;br /&gt;
    &amp;lt;/Customers&amp;gt;&lt;br /&gt;
  &amp;lt;/diffgr:before&amp;gt;&lt;br /&gt;
  &amp;lt;diffgr:errors&amp;gt;&lt;br /&gt;
    &amp;lt;Customers diffgr:id=&amp;quot;Customers2&amp;quot; diffgr:Error=&amp;quot;An optimistic concurrency violation has occurred for this row.&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/diffgr:errors&amp;gt;&lt;br /&gt;
&amp;lt;/diffgr:diffgram&amp;gt;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
DataSet與DataTable也支援直接讀入XML Schema建立結構的能力，以及自行依XML的內容推斷（inference）其結構的能力，下列程式碼為由XML推斷結構的程式：&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
DataSet dataSet = new DataSet();&lt;br /&gt;
dataSet.InferXmlSchema9(&amp;quot;input_od.xml&amp;quot;, new string[] &amp;quot;urn:schemas-microsoft-com:officedata&amp;quot;);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
DataSet和DataTable可以使用XmlDataDocument類別和XML DOM整合在一起，XmlDataDocument的角色就像一個橋接介面，並且作為DataSet和DataTable可使用[[XPath]]與XML DOM方式存取的方法。下列程式碼即為使用XmlDataDocument和資料庫中資料轉換為[[XSLT]]輸出的範例：&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
// Assumes connection is a valid SqlConnection.&lt;br /&gt;
connection.Open();&lt;br /&gt;
&lt;br /&gt;
DataSet custDS = new DataSet(&amp;quot;CustomerDataSet&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
SqlDataAdapter customerAdapter = new SqlDataAdapter(&lt;br /&gt;
  &amp;quot;SELECT * FROM Customers&amp;quot;, connection);&lt;br /&gt;
customerAdapter.Fill(custDS, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
SqlDataAdapter orderAdapter = new SqlDataAdapter(&lt;br /&gt;
  &amp;quot;SELECT * FROM Orders&amp;quot;, connection);&lt;br /&gt;
orderAdapter.Fill(custDS, &amp;quot;Orders&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
connection.Close();&lt;br /&gt;
&lt;br /&gt;
custDS.Relations.Add(&amp;quot;CustOrders&amp;quot;,&lt;br /&gt;
  custDS.Tables[&amp;quot;Customers&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;],&lt;br /&gt;
                     custDS.Tables[&amp;quot;Orders&amp;quot;].Columns[&amp;quot;CustomerID&amp;quot;]).Nested = true;&lt;br /&gt;
&lt;br /&gt;
XmlDataDocument xmlDoc = new XmlDataDocument(custDS); &lt;br /&gt;
&lt;br /&gt;
XslTransform xslTran = new XslTransform();&lt;br /&gt;
xslTran.Load(&amp;quot;transform.xsl&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
XmlTextWriter writer = new XmlTextWriter(&amp;quot;xslt_output.html&amp;quot;, &lt;br /&gt;
  System.Text.Encoding.UTF8);&lt;br /&gt;
&lt;br /&gt;
xslTran.Transform(xmlDoc, null, writer);&lt;br /&gt;
writer.Close();&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
在.NET Framework中，DataSet被分為兩類，一種是不會強制使用特別型態的DataSet，稱為Untyped DataSet，使用上較方便，但沒有強制的型別限制，另一種則是Typed DataSet，會強制型別，並且是由自訂的XML Schema所產生，Untyped DataSet則沒有XML Schema，由建立時的結構來決定，Typed DataSet可以用[[Visual Studio]]，或者是SDK工具中的xsd.exe來產生。&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
xsd.exe /d /l:CS XSDSchemaFileName.xsd /eld /n:XSDSchema.Namespace&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
產生出來的Typed DataSet會自動將欄位設定成屬性，讓開發人員的存取更方便（這個功能在TableAdapter相當常見）。&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;csharp&amp;quot;&amp;gt;&lt;br /&gt;
CustomerDataSet customers = new CustomerDataSet();&lt;br /&gt;
SqlDataAdapter adapter = new SqlDataAdapter(&lt;br /&gt;
  &amp;quot;SELECT * FROM dbo.Customers;&amp;quot;,&lt;br /&gt;
  &amp;quot;Data Source=(local);Integrated &amp;quot; +&lt;br /&gt;
  &amp;quot;Security=SSPI;Initial Catalog=Northwind&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
adapter.Fill(customers, &amp;quot;Customers&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
foreach(CustomerDataSet.CustomersRow customerRow in customers.Customers)&lt;br /&gt;
  Console.WriteLine(customerRow.CustomerID);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== 指令產生器 ==&lt;br /&gt;
&lt;br /&gt;
ADO.NET中有專門用來產生資料處理指令的指令產生器（Command Builder），它可以利用開發人員所指定的&amp;lt;code&amp;gt;SELECT&amp;lt;/code&amp;gt;指令，自動產生對應的&amp;lt;code&amp;gt;INSERT&amp;lt;/code&amp;gt;、&amp;lt;code&amp;gt;UPDATE&amp;lt;/code&amp;gt;與&amp;lt;code&amp;gt;DELETE&amp;lt;/code&amp;gt;指令，但一開始它並不會自動產生，而是要靠呼叫方法來取得：&lt;br /&gt;
&lt;br /&gt;
* &amp;lt;code&amp;gt;DbCommandBuilder.GetInsertCommand()&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;DbCommandBuilder.GetUpdateCommand()&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;DbCommandBuilder.GetDeleteCommand()&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
最常使用到的地方是和DataAdapter並用時，但它要求傳入的&amp;lt;code&amp;gt;SELECT&amp;lt;/code&amp;gt;语句所选择的列集合中必須要有[[主键]]或者[[唯一键]]&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/zh-cn/library/tf579hcz.aspx |title=.NET Framework开发人员指南 - 使用CommandBuilder生成命令（ADO.NET） |accessdate=2009-03-18 |archive-date=2009-03-19 |archive-url=https://web.archive.org/web/20090319164356/http://msdn.microsoft.com/zh-cn/library/tf579hcz.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;，否則無法產生，同時自動產生的指令因為判斷條件很多，對效能可能會有些影响。&lt;br /&gt;
&lt;br /&gt;
== Visual Studio的支援 ==&lt;br /&gt;
&lt;br /&gt;
ADO.NET和Visual Studio開發工具幾乎已經是無縫的整合了，開發人員可以利用Visual Studio來建立強型別（strong-typed）的DataSet，到了Visual Studio 2005時更能夠在[[Windows Forms]]應用程式中使用TableAdapter（Typed DataSet和DataAdapter整合的產物）來開發應用程式（不會再看到DataAdapter，但使用上差不多）&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/zh-tw/library/7zt3ycf2.aspx |title=TableAdapter |accessdate=2009-01-11 |archive-date=2009-09-01 |archive-url=https://web.archive.org/web/20090901215126/http://msdn.microsoft.com/zh-tw/library/7zt3ycf2.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;。Visual Studio在建立Typed DataSet時有提供視覺化介面的支援，以及資料庫組態精靈（Database Configuration Wizard）來讓開發人員以簡單的設定方式來建立DataSet，部分開發人員也將TableAdapter和ASP.NET應用程式的ObjectDataSource控制項並用，亦得到不錯的效果。&lt;br /&gt;
&lt;br /&gt;
在.NET Framework 3.5中，微軟特別為了DataSet和DataTable建立了[[语言集成查询|LINQ]] Provider（稱為LINQ to DataSet或LINQ to ADO.NET），讓LINQ可以在DataSet或DataTable上使用，可以讓原本在DataSet上的投資（程式碼）得以繼續使用並享有LINQ的便利性。&lt;br /&gt;
&lt;br /&gt;
== ADO.NET和ADO的差異 ==&lt;br /&gt;
&lt;br /&gt;
對於ADO的開發人員來說，最明顯的變化在於以往ADO中的Recordset消失了，並且明確的分開為連線型的DataReader以及離線型的DataSet與DataTable，並且發展支援離線型資料來源的瀏覽工具DataView&amp;lt;ref&amp;gt;{{Cite web |url=http://www.microsoft.com/taiwan/msdn/library/2003/Jul-2003-tw/adonetprogmsdn.htm |title=ADO.NET ─ ADO開發人員指引 |accessdate=2006-04-29 |archive-date=2006-01-11 |archive-url=https://web.archive.org/web/20060111020427/http://www.microsoft.com/taiwan/msdn/library/2003/Jul-2003-tw/adonetprogmsdn.htm |dead-url=no }}&amp;lt;/ref&amp;gt;，這樣的改變，讓習慣使用ADO的VB/ASP開發人員會有某種程度的不習慣，同時讓ADO.NET的學習會較ADO有較些許的複雜性，因此有部分新入門或是VB 6.0/ASP開發人員會在學習.NET Framework或是使用VB.NET開發應用程式時，在.NET Framework中使用ADO來連接資料來源。但在.NET Framework應用程式使用ADO的話，.NET Framework會因為要多一層ADO的COM与VB.NET使用的.NET之間的資料轉換，會讓應用程式效能有少部分的損耗&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/en-us/library/ms810295.aspx |title=Revisiting the Use of ADO in .NET Applications |accessdate=2009-01-11 |archive-date=2009-01-13 |archive-url=https://web.archive.org/web/20090113022448/http://msdn.microsoft.com/en-us/library/ms810295.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;。&lt;br /&gt;
&lt;br /&gt;
下述示例，用ADO读取一个数据库中的表格，然后转为ADO.Net的数据，最后绑定到[[DataGridView]]控件中去显示：&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;vbnet&amp;quot;&amp;gt;&lt;br /&gt;
        Dim cn As ADODB.Connection&lt;br /&gt;
        Dim rs As ADODB.Recordset&lt;br /&gt;
        cn = New ADODB.Connection&lt;br /&gt;
        rs = New ADODB.Recordset&lt;br /&gt;
        cn.Provider = &amp;quot;Microsoft.ACE.OLEDB.12.0;&amp;quot;&lt;br /&gt;
        cn.ConnectionString = &amp;quot;D:\\budget2016.accdb;&amp;quot;&lt;br /&gt;
        cn.Open()&lt;br /&gt;
&lt;br /&gt;
        &amp;#039;check whether the serial num exists in table cutter&lt;br /&gt;
        Dim sSQL As String = &amp;quot;SELECT * FROM tPassword&amp;quot; &lt;br /&gt;
        rs.CursorLocation = ADODB.CursorLocationEnum.adUseClient&lt;br /&gt;
        rs.Open(sSQL, cn, ADODB.CursorTypeEnum.adOpenKeyset, ADODB.LockTypeEnum.adLockReadOnly,_ &lt;br /&gt;
                 ADODB.CommandTypeEnum.adCmdText)&lt;br /&gt;
&lt;br /&gt;
        Dim da As New System.Data.OleDb.OleDbDataAdapter()&lt;br /&gt;
        Dim ds As New DataSet()&lt;br /&gt;
        da.Fill(ds, rs, &amp;quot;tPassword&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
        &amp;#039;rs.Close()  &amp;#039;Cannot close &lt;br /&gt;
        rs.ActiveConnection = Nothing&lt;br /&gt;
        cn.Close()&lt;br /&gt;
        rs = Nothing&lt;br /&gt;
        cn = Nothing&lt;br /&gt;
&lt;br /&gt;
        DataGridView1.DataSource = (ds.Tables(&amp;quot;tPassword&amp;quot;))&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
ADO的RecordSet，相当于在客户机或服务器的一个逻辑上的数据表格，使用者可以通过cursor来定位/读写当前行，但不能重新对这些行重新排序，也不能对客户机上的多个RecordSet数据执行跨表的连接（join）查询。ADO.Net针对上述缺点，在客户机上实现了DataTable与DataSet，这是客户机内存中的一套（多个）数据表格，可以对其执行各种单表或多表的查询、修改、删除操作，既可以使用SQL语句，也可以使用LINQ子语言。&lt;br /&gt;
&lt;br /&gt;
ADO与ADO.Net的共同点，在其内部都是使用SQL语句来对后台数据库操作。&lt;br /&gt;
&lt;br /&gt;
内在实现上，ADO是基于COM技术，因此变体类型（Variant）无处不在，这是一种通用、万能类型；而ADO.Net是强类型的，并很好地支持数据库元数据与XML功能。&lt;br /&gt;
&lt;br /&gt;
== ADO.NET的進化 ==&lt;br /&gt;
&lt;br /&gt;
隨著網路應用程式的進化，ADO.NET也隨之做了許多的改變，但不變的是，ADO.NET的基礎提供了強固的發展支援，這些進化的技術都是植基於ADO.NET的核心元件而來。&lt;br /&gt;
&lt;br /&gt;
{{main|Entity Framework}}&lt;br /&gt;
&lt;br /&gt;
長久以來，程式設計師和資料庫總是保持著一種微妙的關係，在商用應用程式中，資料庫一定是不可或缺的元件，這讓程式設計師一定要為了連接與存取資料庫而去學習SQL指令，因此在資訊業中有很多人都在研究如何將程式設計模型和資料庫整合在一起，物件關聯對應（Object-Relational Mapping）的技術就是由此而生，像[[Hibernate]]或NHibernate都是這個技術下的產物，而微軟雖然有了ADO.NET這個資料存取的利器，但卻沒有像NHibernate這樣的物件對應工具，因此微軟在.NET Framework 2.0發展時期，就提出了一個ObjectSpace的概念，ObjectSpace可以讓應用程式可以用完全物件化的方法連接與存取資料庫，其技術概念與NHibernate相當類似，然而ObjectSpace專案相當大，在.NET Framework 2.0完成時仍無法全部完成&amp;lt;ref&amp;gt;{{Cite web |url=http://msdn.microsoft.com/en-us/library/ms971512.aspx |title=A First Look at ObjectSpaces in Visual Studio 2005 |accessdate=2008-08-17 |archive-date=2008-09-05 |archive-url=https://web.archive.org/web/20080905073752/http://msdn.microsoft.com/en-us/library/ms971512.aspx |dead-url=no }}&amp;lt;/ref&amp;gt;，因此微軟將ObjectSpace納入下一版本的.NET Framework中，並且再加上一個設計的工具（Designer），構成了現在的ADO.NET Entity Framework。&lt;br /&gt;
&lt;br /&gt;
Entity Framework利用了抽象化資料結構的方式，將每個資料庫物件都轉換成應用程式物件（entity），而資料欄位都轉換為屬性（property），關聯則轉換為結合屬性（association），讓資料庫的E/R模型完全的轉成物件模型，如此讓程式設計師能用最熟悉的程式語言來呼叫存取。而在抽象化的結構之下，則是高度整合與對應結構的概念層、對應層和儲存層，以及支援Entity Framework的資料提供者（provider），讓資料存取的工作得以順利與完整的進行。&lt;br /&gt;
&lt;br /&gt;
{{main|WCF Data Services}}&lt;br /&gt;
&lt;br /&gt;
以往在發展像是AJAX應用程式時，伺服端總是需要設計一個HTTP介面埠（end point），通常都會使用Web Service來實作，但是隨著Mashup應用程式的成長，若每次都要為一份（或一組）資料撰寫Web Service或HTTP end point的話，對開發人員也是不小的負擔，而且Web Service只支援XML/SOAP的資料格式，無法相容於Mashup應用程式常用的JSON資料格式，微軟也發現未來的Silverlight應用程式也是會面臨到相同問題。&lt;br /&gt;
&lt;br /&gt;
當時剛好微軟的ADO.NET Entity Framework也正在開發中，它的EDM能力剛好可以提供給WCF資料存取的能力，因此微軟特別以ADO.NET Entity Framework為基礎，開發一個專門提供HTTP端點資料服務的資料供應層，即為WCF Data Services。&lt;br /&gt;
&lt;br /&gt;
== 注释 ==&lt;br /&gt;
{{NoteFoot}}&lt;br /&gt;
&lt;br /&gt;
== 参考文献 ==&lt;br /&gt;
{{Reflist|30em}}&lt;br /&gt;
&lt;br /&gt;
== 参见 ==&lt;br /&gt;
* [[ADO|ActiveX Data Objects]]（ADO）&lt;br /&gt;
* [[ODBC|Open Database Connectivity]]（ODBC）&lt;br /&gt;
* [[OLE DB]]&lt;br /&gt;
&lt;br /&gt;
{{-}}&lt;br /&gt;
{{DotNET}}&lt;br /&gt;
{{Microsoft development tools}}&lt;br /&gt;
{{Microsoft APIs}}&lt;br /&gt;
{{Database}}&lt;br /&gt;
&lt;br /&gt;
[[Category:微軟API|A]]&lt;br /&gt;
[[Category:计算机编程|A]]&lt;br /&gt;
[[Category:数据管理|A]]&lt;br /&gt;
[[Category:计算机程序库|A]]&lt;br /&gt;
[[Category:.NET|A]]&lt;br /&gt;
[[Category:数据库API|A]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Shawwww</name></author>
	</entry>
</feed>