dataTable 、dataView、Dataset 區別的經典回答

1、DataView是DataTable的表示,DataTable表裏的記錄是沒有順序的,但顯示可以有不同順序(DataVIew),

但還是同一張表,所以一個DataTable可以有多個DataView,默認訪問DataTable,其實是訪問他的

DefaultView。DataSet則是DataTable的集合,也可以有不止一個DataTable

2、DataView   是一張DataTable的虛擬視圖   ,主要用來顯示數據的   ,其實數據的更改都是發生在DataTable中。

如果以數據庫來打比方,DataSet就是一個功能簡單的數據庫,是多個表(DataTable)的集合,DataTable就是對應數

據庫中的表,而DataView則對應數據庫中的視圖(View)。



ADO.NET中有一層對象,用來創建任意數據源的抽象模型。其中包括DataSet,DataTable,DataRow,DataView,DataRelation等等。

所有這些對象都定義在System.Data名字空間。它們形成一個抽象模型,使得無論針對Windows Form,Web Form還是Web Service進行編程,都可以使用相同的編程接口。
在實際應用中,這些對象大多會對諸如SQL Server一類的關係型數據庫中的數據進行操作。但是,它們可以處理各種數據,而不管它的物理存儲媒介。
你可以使用DataSet對象來打包和關聯各表中的數據,用DataTable類來處理表格類型的數據,而DataRow對象可以處理表中某一行的數據。
這三個對象都是對數據進行打包,但有不同的邏輯聚合層次。DataSet是DataTable和其他的組合。而DataTable是DataRow和其他的組合。DataRow是字段和其他的組合。但是這些對象中都沒有內建過濾和排序的功能。
ADO.NET提供了一些類來處理這個數據庫應用程序中的重要方面。在.Net Beta2中,這方面最重要的兩個對象就是DataView和DataViewManager。
注意:DataViewManager是Beta2中特有的。在Beta1中,相應的功能由DataSetView完成。

定製數據視圖
DataView類用來表示定製的DataTable的視圖。DataTable和DataView的關係是遵循著名的設計模式--文檔/視圖模式,其中DataTable是文檔,而Dataview是視圖。
在任何時候,你都可以有多個基於相同數據的不同的視圖。更重要的是,你可以對每一個具有自己一套屬性、方法、事件的視圖作爲獨立的對象進行處理。這也代表了相對ADO一個巨大的飛躍。
ADO Recordset可以定義過濾字符串。一旦你建立了該字符竄,只有匹配特定標準的數據才能夠進行讀寫。Filter屬性的工作原理同動態WHERE子句很相似。它只是簡單的在同一recordset對象視圖上隱藏了某些記錄。
在ADO中,你從沒有一個獨立的視圖對象。一個過濾過的recordset總是同一個對象,只不過顯示出的記錄比它實際數量少一些而已。
如果你不需要同時處理一些不同的視圖,上述問題並不要緊。編程接口賦予了recordset既可以是表也可以是視圖的功能。但是在創建時,這不能同時發生。在某一特定時刻,recordset只能是沒有過濾字符串的表或者是激活了過濾字符串的視圖。
Recordset 的克隆提供了較好解決這個結構限制的方法。正如Clonation and the Case of Table Dolly, Part 1中所說的,克隆recordset相對開銷較少,因爲它不復制數據,只是複製recordset的基本構造。要處理同一數據兩個或兩個以上的視圖,你可 以利用兩個或兩個以上克隆,各自有一套相應的過濾字符串。


圖一 在ADO中處理同一recordset不同的視圖
在ADO.NET中,你可以使用新型對象模型所提供的DataView對象。ADO.NET的DataView對象用來表示給定數據表的定製的視圖,但你可以像處理單獨的對象一樣處理它。DataView對象保留了對錶的一個引用並允許對它進行更新。


圖二 在ADO.NET中對同一數據表的不同視圖進行操作
功能上而言,使用ADO Recordset克隆與使用特殊的視圖對象完成的是同樣的功能,都是讓你實現過濾,對所選的數據行進行操作,並同時處理多個視圖。

深入DataView對象
DataView對象繼承了MarshalByValueComponent並實現了一組接口使之在數據綁定控件中可用。Public Class DataView
Inherits MarshalByValueComponent
Implements IBindingList, IList, ICollection,IEnumerable, _
ITypedList, ISupportInitialize

由MarshalByValueComponent派生的類是.NET遠程組件,可以通過值來列集--即序列化對象到目標應用程序域。(詳見以下關於.NET組件的更多細節)
DataView中的內容可以通過許多編程接口進行操作,包括集合,列表和枚舉器。IBindingList接口確保了該類提供所有用來支持複雜的和簡單的數據綁定的必要特徵。
總的來說,DataView對象可以用來達到兩個目的。第一,視圖對於關聯DataTable對象和數據綁定控件中的DataSource域是很重要的。第二,它也對連接的DataTable提供了一層包裝,讓你能夠進行過濾,排序,編輯和瀏覽。
DataView並不是唯一的可以通過傳值進行遠程操作的數據驅動類。DataSet和DataTable也具有同樣的能力,特別是在互操作的場景下。

創建DataViewpublic DataView();
public DataView(DataTable);

DataView只有同已經存在的、很可能是非空的DataTable對象連接後纔可用。通常,這個連接在構造時就指定了。
DataView dv;
dv = new DataView(theDataSet.Tables["Employees"]);

但是,你也可以先創建一個新的視圖,然後再用Table屬性同表相關聯。
DataView dv = new DataView();
dv.Table = theDataSet.Tables["Employees"];
DataView構造函數使你由DataTable中得到一個DataView對象。如果需要,反之亦可。事實上,DataTable對象的DefaultView屬性返回一個該表的DataView對象。
DataView dv = dt.DefaultView;

一旦你有了DataView對象, 你可以利用它的屬性來建立你希望用戶見到的數據行集。一般,你可以使用下列屬性:

RowFilter
Sort
前者可以定製視圖中可見數據應匹配的規則。而後者通過表達式來進行排序。當然你可以使用這兩者的任意組合。

設置過濾 RowFilter是一個可讀寫的屬性,用來讀取和設置表過濾的表達式。
public virtual string RowFilter {get; set;}

你可以用列名,邏輯和數字運算符和常量的任意合法組合組成表達式。以下是一些例子:dv.RowFilter = "Country = 'USA'";
dv.RowFilter = "EmployeeID >5 AND Birthdate < #1/31/82#"
dv.RowFilter = "Description LIKE '*product*'"

讓我們來看一下過濾器的基本規則和運算符。
過濾字符串是表達式的邏輯連接。可以用AND,OR,NOT來連接成一個較短的表達式,也可以使用圓括號來組成子句,指定優先的運算。
通常包含列名的子句同字母、數字、日期或另一個列名進行比較。這裏,可以使用關係運算符和算術運算符,如>=, <, >, +, *, % (取模)等等。
如果要選取的行並不能方便地通過算術或邏輯運算符表達,你可以使用IN操作符。以下代碼顯示如何選取一個隨機行:
dv.RowFilter = "employeeID IN (2,4,5)"

你也可以使用通配符*和%,它們同LIKE運算符一起使用時顯得更有用。它們都表示任意數量的字符,可以相互替代使用。
請注意,如果在LIKE子句中已經有了*或%字符,你必須用方括號將其括起,以免歧義。如果很不幸,字符串中方括號本身也存在了,那麼它也必須用將本身括起。這樣,匹配語句會如下所示:
dv.RowFilter = "Description LIKE '[[]*[]]product[[]*[]]"

通配符只允許在過濾字符串的開頭或結尾處使用,而不能在字符串中間出現。例如,下列語句會產生運行時錯誤:
dv.RowFilter = "Description LIKE 'prod*ct"

字符串必須以單引號括起,而日期型必須以#符號括起。字符型值可以使用小數點和科學計數法。
RowFilter也支持聚合函數,如SUM, COUNT, MIN,MAX, and AVG。如果表中沒有數據行,那麼函數將返回NULL。
在介紹RowFilter表達式的最後,讓我們討論三個很便利的函數:Len,IIF和Substring。
正如其名,Len()返回特定表達式的長度。該表達式可以是一個列名,也可以是其他合法的表達式。
Substring()返回指定的表達式自特定位置開始,特定長度的字符子串。
我最喜歡用的是IIF(),它按照邏輯表達式的值有一到兩個值。IIF是IF-THEN-ELSE語句的緊湊表達。語法如下:
IIF(expression, if_true, if_false)

通 過該函數,可以建立非常複雜的過濾字符串。例如,假定你從SQL Server的Northwind數據庫中取得Employees表,下列表達式可以選出那些employeeID小於6且lastname爲偶數個字符 和employeeID大於6且lastname爲奇數個字符的員工。
IIF(employeeID<6, Len(lastname) %2 =0, Len(lastname) %2 >0)

下圖顯示了結果(樣品應用程序會在稍後討論)

圖三 對Northwind中的表進行過濾
例子程序是一個Windows® Form應用程序,其中使用了兩個datagrid
控件來實現master/detail結構。一個grid在載入時生成,即在SQL
Server data adapter完成數據讀取工作之後。請注意,data
adapter是Beta 2中引入的,在Beta 1中相應的是SQLDataSetCommand類。


預排視圖
在上面的舉例中,datagrid必須負責預排視圖中的數據行,以便刷新用戶界面。這個自動機制是.NET
數據綁定的產物。Datagrid是通過DataSource屬性來獲取數據的數據綁定控件。DataView是一個可數據綁定的類,可構建DataSource屬性的內容。

如果你想使用datagrid之外的另一個控件,應該怎麼辦呢?又如果你不想使用自動數據綁定呢?應該怎樣預排視圖中所選的數據行呢?


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章