C#之資料集:DataSet物件
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中的完整程式碼為:
<span style="font-size:18px;">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(); } } } </span>
執行結果為:
複製DataSet內容
在上面的表中可以看出要複製DataSet物件中的內容,有兩種形式,一種是複製該DataSet的結果但不復制資料,是由Clone方法實現的。其格式為:DataSet物件.Clone();另一種是既複製結構也複製了資料,是由Copy方法實現的,其格式為:DataSet物件.Copy();
例項:建立衣蛾DataSet資料集,該資料集包含一個表,兩個列和六行資料,然後分別建立兩個DataSet物件,分別通過Clone方法和Copy方法進行DataSet的內容複製的完整程式碼:
<span style="font-size:18px;">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();
}
}
}
</span>
執行的結果為: