程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#之數據集:DataSet對象

C#之數據集:DataSet對象

編輯:C#入門知識

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中的完整代碼為:

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();
        }
        
    }
}

運行的結果為:

\

 

 

 

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved