1. 程式人生 > >C#之資料集:DataSet物件

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>

        執行的結果為: