C#使用SQL Dataset數(shù)據(jù)集代碼實例
ADO.NET數(shù)據(jù)訪問技術的一個突出特點就是支持離線訪問,而實現(xiàn)這種離線訪問的技術核心急速DataSet對象,該對象通過數(shù)據(jù)駐留在內存來實現(xiàn)離線訪問。
DataSet對象由一組DataTable對象組成,這些對象與DataRelation對象又包含Row(行),集合,Columns(列)集合,Rows集合是有多個DAtaRow對象組成,Columns集合是由多個Datacolumns對象組成。
步驟:
1,引入命名空間System.Data;
2,創(chuàng)建DataSet對象
3,創(chuàng)建DataTable對象
4,將DataTable對象加入DataSet 對象中
5,定義列,并向DataTableh中增加已經(jīng)定義好的列
6,插入行數(shù)據(jù)
7,進行相關的操作
代碼演示:
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); //添加
//聲明三個列
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ā)部" }, { "李四","技術部" }, { "王五","網(wǎng)絡部" }, { "趙六","人事部" } };
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 復制該DataSet的結構但不復制數(shù)據(jù)
- Copy 復制DataSet結構和數(shù)據(jù)
- Dispose 釋放DataSet對象
- Equals 確定兩個DataSet對象是否 相同
- Merge 將指定的DataSet DataTable 或DataRow 對象的數(shù)組并合并到當前地DataSet或DataTable中
- Reset 將DataSet重置為初始狀態(tài)
小實例: 合并DataSet內容,復制DataSet內容
基于上面的代碼繼續(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); //添加
//聲明三個列
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ā)部" }, { "李四","技術部" }, { "王五","網(wǎng)絡部" }, { "趙六","人事部" } };
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); //調用遍歷方法
//創(chuàng)建第二個表
DataTable mydt02 = mydt.Clone();
DataRow mydr02 = mydt02.NewRow();
mydt02.Rows.Add(new Object[] { 5,"Czhenya","開發(fā)部"});
mydt02.Rows.Add(new Object[] { 5, "陳九", "開發(fā)部" });
//------合并兩個表------
myds.Merge(mydt02); //將其架構合并到myds中
Console.WriteLine("-----合并后的表-----");
outValues(myds);
//------復制--------
DataSet myds01 = myds.Copy();
DataSet myds02 = myds.Clone();
Console.WriteLine("COPY的結果");
outValues(myds01); //完全復制
Console.WriteLine("Clone的結果");
outValues(myds02); //克隆出框架,不復制數(shù)據(jù)
Console.Read();
}
/// <summary>
/// 實現(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();
}
}
}
}
}
}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
C#?在PDF中添加墨跡注釋Ink?Annotation的步驟詳解
PDF中的墨跡注釋表現(xiàn)為徒手涂鴉式的形狀,該類型的注釋,可任意指定形狀頂點的位置及個數(shù),通過指定的頂點,程序將連接各點繪制成平滑的曲線,下面通過C#程序代碼介紹下在pdf中添加注釋的步驟,感興趣的朋友一起看看吧2022-02-02
C# PC版微信消息監(jiān)聽自動回復的實現(xiàn)方法
這篇文章主要介紹了C# PC版微信消息監(jiān)聽自動回復的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-05-05

