C#使用SQL Dataset數(shù)據(jù)集代碼實(shí)例
ADO.NET數(shù)據(jù)訪問技術(shù)的一個(gè)突出特點(diǎn)就是支持離線訪問,而實(shí)現(xiàn)這種離線訪問的技術(shù)核心急速DataSet對(duì)象,該對(duì)象通過數(shù)據(jù)駐留在內(nèi)存來實(shí)現(xiàn)離線訪問。
DataSet對(duì)象由一組DataTable對(duì)象組成,這些對(duì)象與DataRelation對(duì)象又包含Row(行),集合,Columns(列)集合,Rows集合是有多個(gè)DAtaRow對(duì)象組成,Columns集合是由多個(gè)Datacolumns對(duì)象組成。
步驟:
1,引入命名空間System.Data;
2,創(chuàng)建DataSet對(duì)象
3,創(chuàng)建DataTable對(duì)象
4,將DataTable對(duì)象加入DataSet 對(duì)象中
5,定義列,并向DataTableh中增加已經(jīng)定義好的列
6,插入行數(shù)據(jù)
7,進(jìn)行相關(guān)的操作
代碼演示:
namespace DataSetDemo { class Program { static void Main(string[] args) { //創(chuàng)建DataSet對(duì)象 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 常用簡(jiǎn)單方法
- Clear 移除表中所有含來清除任何數(shù)據(jù)的DataSet;
- Clone 復(fù)制該DataSet的結(jié)構(gòu)但不復(fù)制數(shù)據(jù)
- Copy 復(fù)制DataSet結(jié)構(gòu)和數(shù)據(jù)
- Dispose 釋放DataSet對(duì)象
- Equals 確定兩個(gè)DataSet對(duì)象是否 相同
- Merge 將指定的DataSet DataTable 或DataRow 對(duì)象的數(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對(duì)象 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é)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)我們的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
上一篇:C#使用Aspose.Cells創(chuàng)建和讀取Excel文件
欄 目:C#教程
下一篇:C#抽象類與抽象方法詳解
本文標(biāo)題:C#使用SQL Dataset數(shù)據(jù)集代碼實(shí)例
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5037.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動(dòng)對(duì)資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#使用windows服務(wù)開啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫的方法
- 01-10C#使用Mutex簡(jiǎn)單實(shí)現(xiàn)程序單實(shí)例運(yùn)行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#將圖片存放到SQL SERVER數(shù)據(jù)庫中的方法
- 01-10C#中實(shí)現(xiàn)一次執(zhí)行多條帶GO的sql語句實(shí)例
- 01-10C#訪問SQL Server數(shù)據(jù)庫的實(shí)現(xiàn)方法


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery