ADO.NET數據訪問技術的一個突出的特點就是支持離線訪問,而實現這種離線訪問技術的核心就是DataSet對象,該對象通過將數據駐留在內存來實現離線訪問。
DataSet對象概述
DataSet對象由一組DataTable對象組成,這些對象與DataRelation對象互相關聯。這些DataSet對象又包含Rows集合,Columns集合,Rows集合由多個DataRow對象組成,Columns集合由多個DataColumn對象組成。
由於DataSet對象很像數據庫,所以可以像訪問關系型數據庫那樣訪問DataSet,例如在DataSet中添加,刪除表,在表中進行查詢數據,刪除數據等操作。
DataSet對象有常用的方法:
合並DataSet內容
在上面的表中可以看出,合並DataSet對象中的內容是通過Merge方法來實現的。Merge方法有多種重載,但是一般我們會遇到三種常見的重載,因此只是說明一些常見的重載:
(1)DataSet對象.Merge(DataRow[]);//將DataRow對象數組合並到當前的DataSet中
(2)DataSet對象.Merge(DataTable);//將指定的DataTable及其架構合並到當前的DataSet中
(3)DataSet對象.Merge(DataSet);//將DataSet及其架構合並到當前的DataSet中
實例:使用第二個重載方法創建一個DataSet數據集,該數據集包含一個表,兩個列和六行數據。然後創建與第一個表相同的第二個DataTable。向第二個表中添加兩行,然後將該表合並到DataSet中的完整代碼為:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Data;//引入的命名空間 namespace ConsoleApplication4 { class Program { public static void PrintValues(DataSet ds)//輸出各表中的數據 { foreach (DataTable table in ds.Tables) { Console.WriteLine("表名稱:" + table.TableName); foreach (DataRow row in table.Rows) { foreach (DataColumn column in table.Columns) { Console.Write(row[column] + ""); } Console.WriteLine(); } } } static void Main(string[] args) { DataSet ds = new DataSet("dsText");//創建DataSet對象 DataTable dt = new DataTable("tableText");//創建DataTable對象 ds.Tables.Add(dt);//將DataTable對象加入到ds中 DataColumn dc1 = new DataColumn("id",Type.GetType("System.Int32"),"");//創建第一列 DataColumn dc2 = new DataColumn("Item", Type.GetType("System.String"), "");//創建第二列 dt.Columns.Add(dc1);//向DataTable中添加一列 dt.Columns.Add(dc2);//向DataTable中添加一列 for (int i = 0; i < 6; i++)//向dt中添加數據 { DataRow dr = dt.NewRow();//在dt中新建一行 dr["id"] = i;//向第一列插入數據 dr["Item"] = "項" + i;//向第二列插入數據 dt.Rows.Add(dr);//向dt中添加一行 } ds.AcceptChanges();//加載上次更改後的數據 Console.WriteLine("合並前的數據集"); Program.PrintValues(ds);//輸出ds中的表中的數據 DataTable dt1 = dt.Clone();//克隆dt DataRow newRow; newRow = dt1.NewRow();//添加行 newRow["id"] = 0; newRow["Item"] = ""; dt1.Rows.Add(new object[] { 8, "項8" }); dt1.Rows.Add(new object[] { 9, "項9" }); ds.Merge(dt1);//將dt1合並到ds中 Console.WriteLine("\n"+"合並後的數據集"); Program.PrintValues(ds);//輸出ds中的數據 Console.ReadLine(); } } }
運行結果為:
復制DataSet內容
在上面的表中可以看出要復制DataSet對象中的內容,有兩種形式,一種是復制該DataSet的結果但不復制數據,是由Clone方法實現的。其格式為:DataSet對象.Clone();另一種是既復制結構也復制了數據,是由Copy方法實現的,其格式為:DataSet對象.Copy();
實例:創建衣蛾DataSet數據集,該數據集包含一個表,兩個列和六行數據,然後分別創建兩個DataSet對象,分別通過Clone方法和Copy方法進行DataSet的內容復制的完整代碼:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Data;//引入的命名空間 namespace ConsoleApplication4 { class Program { public static void PrintValues(DataSet ds)//輸出各表中的數據 { foreach (DataTable table in ds.Tables) { Console.WriteLine("表名稱:" + table.TableName); foreach (DataRow row in table.Rows) { foreach (DataColumn column in table.Columns) { Console.Write(row[column] + ""); } Console.WriteLine(); } } } static void Main(string[] args) { DataSet ds = new DataSet("dsText");//創建DataSet對象 DataTable dt = new DataTable("tableText");//創建DataTable對象 ds.Tables.Add(dt);//將DataTable對象加入到ds中 DataColumn dc1 = new DataColumn("id",Type.GetType("System.Int32"),"");//創建第一列 DataColumn dc2 = new DataColumn("Item", Type.GetType("System.String"), "");//創建第二列 dt.Columns.Add(dc1);//向DataTable中添加一列 dt.Columns.Add(dc2);//向DataTable中添加一列 for (int i = 0; i < 6; i++)//向dt中添加數據 { DataRow dr = dt.NewRow();//在dt中新建一行 dr["id"] = i;//向第一列插入數據 dr["Item"] = "項" + i;//向第二列插入數據 dt.Rows.Add(dr);//向dt中添加一行 } ds.AcceptChanges();//加載上次更改後的數據 Console.WriteLine("源數據集"); Program.PrintValues(ds);//輸出ds中的表中的數據 DataSet ds1 = ds.Clone();//復制框架 DataSet ds2 = ds.Copy();//復制框架和數據 Console.WriteLine("\n"+"Clone方法"); Program.PrintValues(ds1);//輸出ds中的數據 Console.WriteLine("\n" + "Copy方法"); Program.PrintValues(ds2);//輸出ds中的數據 Console.ReadLine(); } } }
運行的結果為: