C#使用SQL Dataset數(shù)據(jù)集代碼實(shí)例
ADO.NET數(shù)據(jù)訪問技術(shù)的一個(gè)突出特點(diǎn)就是支持離線訪問,而實(shí)現(xiàn)這種離線訪問的技術(shù)核心急速DataSet對象,該對象通過數(shù)據(jù)駐留在內(nèi)存來實(shí)現(xiàn)離線訪問。
DataSet對象由一組DataTable對象組成,這些對象與DataRelation對象又包含Row(行),集合,Columns(列)集合,Rows集合是有多個(gè)DAtaRow對象組成,Columns集合是由多個(gè)Datacolumns對象組成。
步驟:
1,引入命名空間System.Data;
2,創(chuàng)建DataSet對象
3,創(chuàng)建DataTable對象
4,將DataTable對象加入DataSet 對象中
5,定義列,并向DataTableh中增加已經(jīng)定義好的列
6,插入行數(shù)據(jù)
7,進(jìn)行相關(guān)的操作
代碼演示:
namespace DataSetDemo { class Program { static void Main(string[] args) { //創(chuàng)建DataSet對象 DataSet myds = new DataSet("mycsharp"); DataTable mydt = new DataTable("mytable01"); myds.Tables.Add(mydt); //添加 //聲明三個(gè)列 DataColumn mydcol1 = new DataColumn("id",Type.GetType("System.Int32")); DataColumn mydcol2 = new DataColumn("name", Type.GetType("System.String")); DataColumn mydcol3 = new DataColumn("department", Type.GetType("System.String")); //添加定義好的列 mydt.Columns.Add(mydcol1); mydt.Columns.Add(mydcol2); mydt.Columns.Add(mydcol3); //輸入數(shù)據(jù) string[,] mystr= { { "張三","開發(fā)部" }, { "李四","技術(shù)部" }, { "王五","網(wǎng)絡(luò)部" }, { "趙六","人事部" } }; for (int i=0; i< mystr.Length/2;i++) { DataRow myrow = mydt.NewRow(); //增加新的行 myrow[0] = i; myrow["name"] = mystr[i, 0]; myrow[2] = mystr[i, 1]; mydt.Rows.Add(myrow); } myds.AcceptChanges(); //保存 } } }
DataSet 常用簡單方法
- Clear 移除表中所有含來清除任何數(shù)據(jù)的DataSet;
- Clone 復(fù)制該DataSet的結(jié)構(gòu)但不復(fù)制數(shù)據(jù)
- Copy 復(fù)制DataSet結(jié)構(gòu)和數(shù)據(jù)
- Dispose 釋放DataSet對象
- Equals 確定兩個(gè)DataSet對象是否 相同
- Merge 將指定的DataSet DataTable 或DataRow 對象的數(shù)組并合并到當(dāng)前地DataSet或DataTable中
- Reset 將DataSet重置為初始狀態(tài)
小實(shí)例: 合并DataSet內(nèi)容,復(fù)制DataSet內(nèi)容
基于上面的代碼繼續(xù)寫:
namespace DataSetDemo { class Program { static void Main(string[] args) { //創(chuàng)建DataSet對象 DataSet myds = new DataSet("mycsharp"); DataTable mydt = new DataTable("mytable01"); myds.Tables.Add(mydt); //添加 //聲明三個(gè)列 DataColumn mydcol1 = new DataColumn("id",Type.GetType("System.Int32")); DataColumn mydcol2 = new DataColumn("name", Type.GetType("System.String")); DataColumn mydcol3 = new DataColumn("department", Type.GetType("System.String")); //添加定義好的列 mydt.Columns.Add(mydcol1); mydt.Columns.Add(mydcol2); mydt.Columns.Add(mydcol3); //輸入數(shù)據(jù) string[,] mystr= { { "張三","開發(fā)部" }, { "李四","技術(shù)部" }, { "王五","網(wǎng)絡(luò)部" }, { "趙六","人事部" } }; for (int i=0; i< mystr.Length/2;i++) { DataRow myrow = mydt.NewRow(); //增加新的行 myrow[0] = i+1; myrow["name"] = mystr[i, 0]; //使用字符串 myrow[2] = mystr[i, 1]; mydt.Rows.Add(myrow); } myds.AcceptChanges(); //保存 Console.WriteLine("更改前的數(shù)據(jù)"); outValues(myds); //調(diào)用遍歷方法 //創(chuàng)建第二個(gè)表 DataTable mydt02 = mydt.Clone(); DataRow mydr02 = mydt02.NewRow(); mydt02.Rows.Add(new Object[] { 5,"Czhenya","開發(fā)部"}); mydt02.Rows.Add(new Object[] { 5, "陳九", "開發(fā)部" }); //------合并兩個(gè)表------ myds.Merge(mydt02); //將其架構(gòu)合并到myds中 Console.WriteLine("-----合并后的表-----"); outValues(myds); //------復(fù)制-------- DataSet myds01 = myds.Copy(); DataSet myds02 = myds.Clone(); Console.WriteLine("COPY的結(jié)果"); outValues(myds01); //完全復(fù)制 Console.WriteLine("Clone的結(jié)果"); outValues(myds02); //克隆出框架,不復(fù)制數(shù)據(jù) Console.Read(); } /// <summary> /// 實(shí)現(xiàn)遍歷dataset /// </summary> /// <param name="ds">DataSet名稱</param> public static void outValues(DataSet ds) { foreach (DataTable outtable in ds.Tables) { Console.WriteLine("表名稱:"+ outtable.TableName); foreach (DataRow outdr in outtable.Rows) { foreach (DataColumn ourdcol in outtable.Columns) { Console.Write(outdr[ourdcol] + "\t"); Console.WriteLine(); } } } } } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
C#實(shí)現(xiàn)DevExpress本地化實(shí)例詳解
這篇文章主要介紹了C#實(shí)現(xiàn)DevExpress本地化,以實(shí)例形式較為詳細(xì)的分析了DevExpress本地化的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08C#短時(shí)間內(nèi)產(chǎn)生大量不重復(fù)的隨機(jī)數(shù)
在C#編程中,經(jīng)常會(huì)碰到產(chǎn)生隨機(jī)數(shù)的情況,并且是在短時(shí)間內(nèi)產(chǎn)生一組隨機(jī)數(shù)。如果這組隨機(jī)數(shù)中有大量重復(fù)的,則達(dá)不到我們的要求2013-02-02C#?在PDF中添加墨跡注釋Ink?Annotation的步驟詳解
PDF中的墨跡注釋表現(xiàn)為徒手涂鴉式的形狀,該類型的注釋,可任意指定形狀頂點(diǎn)的位置及個(gè)數(shù),通過指定的頂點(diǎn),程序?qū)⑦B接各點(diǎn)繪制成平滑的曲線,下面通過C#程序代碼介紹下在pdf中添加注釋的步驟,感興趣的朋友一起看看吧2022-02-02C#中利用代理實(shí)現(xiàn)觀察者設(shè)計(jì)模式詳解
學(xué)習(xí)模式注重精髓而非模板,本文為了便于說明假定了三方并對三方功能進(jìn)行了劃分,實(shí)際應(yīng)用并不拘泥于此。如果情況合適將數(shù)據(jù)(文檔)類設(shè)計(jì)為單件模式也是一種很不錯(cuò)的選擇2014-01-01c# 如何實(shí)現(xiàn)自動(dòng)更新程序
這篇文章主要介紹了如何用c# 自動(dòng)更新程序,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下2021-03-03C# PC版微信消息監(jiān)聽自動(dòng)回復(fù)的實(shí)現(xiàn)方法
這篇文章主要介紹了C# PC版微信消息監(jiān)聽自動(dòng)回復(fù)的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05