zoukankan      html  css  js  c++  java
  • DataSet用法详细 转 武胜

    DataSet用法详细

    一、特点介绍

    1、处理脱机数据,在多层应用程序中很有用。

    2、可以在任何时候查看DataSet中任意行的内容,允许修改查询结果的方法。

    3、处理分级数据

    4、缓存更改

    5、XML的完整性:DataSet对象和XML文档几乎是可互换的。

    二、使用介绍

    1、创建DataSet对象:

    DataSetds = new DataSet("DataSetName");

    2、查看调用SqlDataAdapter.Fill创建的结构

    da.Fill(ds,"Orders");

    DataTabletbl = ds.Table[0];

    foreach(DataColumncol in tbl.Columns)

    Console.WriteLine(col.ColumnName);

    3、查看SqlDataAdapter返回的数据

    ①DataRow对象

    DataTabletbl = ds.Table[0];

    DataRowrow = tbl.Row[0];

    Console.WriteLine(ros["OrderID"]);

    ②检查存储在DataRow中的数据

    DataTabletbl = row.Table;

    foreach(DataColumncol in tbl.Columns)

    Console.WriteLine(row[col]);

    ③检查DatTable中的DataRow对象

    foreach(DataRowrow in tbl.Rows)

    DisplayRow(row);

    4、校验DataSet中的数据

    ①校验DataColumn的属性:ReadOnly,AllowDBNull,MaxLength,Unique

    ②DataTable对象的Constrains集合:UiqueConstraints,Primarykey,ForeignkeyConstraints

    通常不必刻意去创建ForeignkeyConstraints,因为当在DataSet的两个DataTable对象之间创建关系时会创建一个。

    ③用SqlDataAdapter.Fill模式来检索模式信息

    5、编写代码创建DataTable对象

    ①创建DataTable对象:

    DataTabletbl = new DataTable("TableName");

    ②将DataTable添加到DataSet对象的Table集合

    DataSetds = new DataSet();

    DataTabletbl = new DataTable("Customers");

    ds.Tables.Add(tbl);

    DataSetds = new DataSet();

    DataTabletbl = ds.Tables.Add("Customers");

    DataTable对象只能存在于至多一个DataSet对象中。如果希望将DataTable添加到多个DataSet中,就必须使用Copy方 法或Clone方法。Copy方法创建一个与原DataTable结构相同并且包含相同行的新DataTable;Clone方法创建一个与原 DataTable结构相同,但没有包含任何行的新DataTable。

    ③为DataTable添加列

    DataTabletbl = ds.Tables.Add("Orders");

    DataColumncol =tbl.Columns.Add("OrderID",typeof(int));

    col.AllowDBNull= false;

    col.MaxLength= 5;

    col.Unique= true;

    tbl.PrimaryKey= new DataColumn[]{tbl.Columns["CustomersID"]};

    当设置主键时,AllowDBNull自动设置为False;

    ④处理自动增量列

    DataSetds = new DataSet();

    DataTabletbl = ds.Tables.Add("Orders");

    DataColumncol = tbl.Columns.Add("OrderID",typeof(int));

    col.AutoIncrement= true;

    col.AutoIncrementSeed= -1;

    col.AutoIncrementStep= -1;

    col.ReadOnly= true;

    ⑤添加基于表达式的列

    tbl.Columns.Add("ItemTotal",typeof(Decimal),"Quantity*UnitPrice");

    6、修改DataTable内容

    ①添加新DataRow

    DataRowrow = ds.Tables["Customers"].NewRow();

    row["CustomerID"]= "ALFKI";

    ds.Tables["Customers"].Rows.Add(row);

    object[]aValues={"ALFKI","Alfreds","Anders","030-22222"};

    da.Tables["Customers"].LoadDataRow(aValues,false);

    ②修改当前行

    修改行的内容逼供内不会自动修改数据库中相应的内容,对行所做的修改被视为是随后将使用SqlDataAdapter对象来提交交给数据库的待定的更改。

    DataRowrowCustomer;

    rowCustomer= ds.Tables["Custoemrs"].Rows.Find("ANTON");

    if(rowCustomer== null)

        //没有查找客户

    else

    {

        rowCustomer["CompanyName"]="NewCompanyName";

        rowCustomer["ContactName"]="NewContactName";

    }

     

    //推荐使用这种方式

    DataRowrowCustomer;

    rowCustomer= ds.Tables["Custoemrs"].Rows.Find("ANTON");

    if(rowCustomer== null)

        //没有查找客户

    else

    {

        rowCustomer.BeginEdit();

        rowCustomer["CompanyName"]="NewCompanyName";

        rowCustomer["ContactName"]="NewContactName";

        rowCustomer.EndEdit();

    }

    //null表示不修改该列的数据

    obejct[]aCustomer ={null,"NewCompanyName","NewContactName",null}

    DataRowrowCustomer;

    rowCustomer= ds.Tables["Customers"].Rows.Find("ALFKI");

    rowCustomer.ItemArray= aCustomer;

    ③处理DataRow的空值

    //查看是否为空

    DataRowrowCustomer;

    rowCustomer= ds.Tables["Customers"].Rows.Find("ALFKI");

    if(rowCustomer.IsNull("Phone"))

    Console.WriteLine("It''''sNull");

    else

    Console.WriteLine("It''''snot Null");

     

    //赋予空值

    rowCustomer["Phone"]= DBNull.Value;

    ④删除DataRow

    DataRowrowCustomer;

    rowCustomer= ds.Tables["Customers"].Rows.Find("ALFKI");

    rowCustomer.Delete();

    ⑤清除DataRow

    DataRowrowCustomer = ds.Tables["Customers"].Rows.Find("ALFKI");

    rowCustomer.ItemArray= aCustomer;

    da.Tables["Customers"].Remove(rowCustomer);

    或者

    ds.Tables["Customers"].RemoveAt(intIndex);

    ⑥使用DataRow.RowState属性 :Unchanged,Detached,Added,Modified,Deleted

    privatevoid DemonstrateRowState()

    {

        // Run a function to create a DataTablewith one column.

        DataTable myTable = MakeTable();

        DataRow myRow;

        // Create a new DataRow.

        myRow = myTable.NewRow();

        // Detached row.

        Console.WriteLine("New Row " +myRow.RowState);

        myTable.Rows.Add(myRow);

        // New row.

        Console.WriteLine("AddRow " +myRow.RowState);

        myTable.AcceptChanges();

        // Unchanged row.

        Console.WriteLine("AcceptChanges" + myRow.RowState);

        myRow["FirstName"] ="Scott";

        // Modified row.

        Console.WriteLine("Modified " +myRow.RowState);

        myRow.Delete();

        // Deleted row.

        Console.WriteLine("Deleted " +myRow.RowState);

    }

    ⑦检查DataRow中的挂起更改

    DataRowrowCustomer;

    rowCustomer= ds.Tables["Customers"].Rows.Find("ALFKI");

    rowCustomer["CompanyName"]= "NewCompanyName";

    stringstrNewCompanyName,strOldCompanyName;

    Console.WriteLine(rowCustomer["CompanyName",DataRowVersion.Current]);

    Console.WriteLine(rowCustomer["CompanyName",DataRowVersion.Original]);

    ⑧遍历DataSet

    foreach(DataTabledt in dataSet.Tables)

    foreach(DataRowdr in dt.Rows)

    foreach(DataColumndc in dr.Table.Columns)

    Console.WriteLine(dr[dc]);

    三、属性方法事件介绍

    1、DataSet

    ①属性

    CaseSensitive:用于控制DataTable中的字符串比较是否区分大小写。

    DataSetName:当前DataSet的名称。如果不指定,则该属性值设置为"NewDataSet"。如果将DataSet内容写入XML文件,DataSetName是XML文件的根节点名称。

    DesignMode:如果在设计时使用组件中的DataSet,DesignMode返回True,否则返回False。

    HasErrors:表示DataSet中 的DataRow对象是否包含错误。如果将一批更改提交给数据库并将DataAdapter对象的ContinueUpdateOnError属性设置为 True,则在提交更改后必须检查DataSet的HasErrors属性,以确定是否有更新失败。

    NameSpacePrefix:指定XML命名空间和前缀

    Relations:返回一个DataRelationCollection对象。

    Tables:检查现有的DataTable对象。通过索引访问DataTable有更好的性能。

    ②方法

    AcceptChangesRejectChanges: 接受或放弃DataSet中所有挂起更改。调用AcceptChanges时,RowState属性值为Added或Modified的所有行的 RowState属性都将被设置为UnChanged.任何标记为Deleted的DataRow对象将从DataSet中删除。调用 RejectChanges时,任何标记为Added的DataRow对象将会被从DataSet中删除,其他修改过的DatRow对象将返回前一状态。

    Clear:清除DataSet中所有DataRow对象。该方法比释放一个DataSet然后再创建一个相同结构的新DataSet要快。

    CloneCopy:使用Copy方法会创建与原DataSet具有相同结构和相同行的新DataSet。使用Clone方法会创建具有相同结构的新DataSet,但不包含任何行。

    GetChanges:返回与原DataSet对象具有相同结构的新DataSet,并且还包含原DataSet中所有挂起更改的行。

    GetXmlGetXmlSchema:使用GetXml方法得到由DataSet的内容与她的架构信息转换为XML格式后的字符串。如果只希望返回架构信息,可以使用GetXmlSchema。

    HasChange:表示DataSet中是否包含挂起更改的DataRow对象。

    Merge:从另一个DataSet、DataTable或现有DataSet中的一组DataRow对象载入数据。

    ReadXmlWriteXml:使用ReadXml方法从文件、TextReader、数据流或者XmlReader中将XML数据载入DataSet中。

    Reset:将DataSet返回为未初始化状态。如果想放弃现有DataSet并且开始处理新的DataSet,使用Reset方法比创建一个DataSet的新实例好。

    ③事件

    MergeFailed:在DataSet的Merge方法发生一个异常时触发。

    2、DataTable

    ①属性

    ②方法

    ③事件

    ColumnChanged:在列的内容被改变之后触发

    ColumnChangding:在列的内容被改变之前触发

    RowChanged,RowChanging,RowDeleted,RowDeleting

    3、DataColumn

    ①属性

    4、DataRow

    ①属性

    HasError:确定行是否包含错误。

    Item:通过指定行的列数,列的名称或DataColumn对象本身,访问列的内容。

    ItemArray:获取或设置行中所有列的值。

    RowError:返回一个包含行错误信息的字符串。

    RowState:返回DataRowState枚举中的值来表示行的当前状态。

    Table:返回DataRow对象所在的DataTable。

    ②方法

    AcceptChangesRejectChanges:提交和放弃挂起更改。

    BeginEditCancelEditEndEdit

    ClearErrors:清除DataRow中所有的错误。

    Delete:Delete方法实际上并不从DataRow表的Row集合中删除该DataRow。当调用DataRow对象的Delete方法时,ADO.NET将该行标记为删除,之后调用SqlDataAdapter对象的Update方法来删除其在数据库中对应的行。

    如果希望彻底删除DataRow,可以调用Delete方法,接着再调用它的AccepteChanges方法,还可以使用DataRowCollection对象的Remove方法完成相同的任务。

    datasetds =new datast();

    datatabletel =new datatable();

    ds..tables.add(tel);

    stringcode=ds.tables["tel"].rows[0][0].tostring();

    浅谈DataSet 的用法

    DataSet 是ADO.NET开发人员为方便数据处理开发出来的,是数据的集合,是为解决DataReader的缺陷设计的,DataReader数据处理速度快,但 它是只读的,而且一旦移到下一行,就不能查看上一行的数据,DataSet则可以自由移动指针。DataSet的数据是与数据库断开的。DataSet 还可用于多层应用程序中,如果应用程序运行在中间层的业务对象中来访问数据库,则业务对象需将脱机数据结构传递给客户应用程序。

    DataSet的功能:浏览、排序、搜索、过滤、处理分级数据、缓存更改等。还可以与XML数据互换。DataSet中可包括多个 DataTable,可将多个查询结构存到一个DataSet中,方便操作,而DataTable中又包括多个DataRow、DataColumn,可 通过这些 DataRow、DataColumn来查看、操作其中的数据,而需将操作结果返回给数据库的话,则可以调用DataAdapter的Update方法。

    DataSet的操作:

    DataSetds=new DataSet();

    DataTabledt=new DataTable("newTable");

    ds.Tables.Add(dt);

    DataSetds=new DataSet();

    DataTabledt=ds.Tables.Add("newTable");

    上述两种方法都可以在DataSet中添加一个DataTable,看需要而进行选择。添加DataTable后,需向其中添加行和列。

    DataSetds=new DataSet();

    DataTabledt=ds.Tables.Add("newTables");

    DataColumncol=dt.Columns.Add("newColumn",typeof(int));

    col.AllowDBNull=false;

    col.MaxLength=4;

    col.Unique=true;

    上述代码向DataSet中的DataTable中添加名为”newColumn”,类型为int且不为空,最大长度为4和唯一性为真的列。

    dt.PrimaryKey=newDataColumn[]{dt.Columns["ID"]}

    这段代码是继续上面代码的,为一个DataTable中添加一个主键列,主键列是一个数据组,如有多个主键,只需在数组中添加一个列即可。如下:

    dt.PrimaryKey=newDataColumns[]{dt.Columns["OrderID"],dt.Columns["ProductID"]}

    添加外键:

    ForeignKeyConstraintfk;

    fk=newForeignKeyConstraint(ds.Tables["Customers"].Columns["CustomerID"],ds.Tables["Orders"].Columns["CustomerID"]);

    ds.Tables["Orders"].Constraints.Add(fk);

    上述代码假如已经为Cusomers表和Orders创建了主键,此句为添加外键约束。

    上述是根据Customers表和Orders表的CustomerID来创建约束。

    下面介绍修改DataRow中的内容:

    DataRowdr=ds.Tables["Customer"].Rows.Find("ANTON");

    if(dr==null)

    else

    {

        dr.BeginEdit();

        dr["CompanyName"]="newValue";

        dr["ContactName"]="newValue2";

        dr.EndEdit();

    }

    上面代码通过Row集合的Find方法来在DataTable中的行进行定位,找到"ANTON"行,再修改"ANTON"行中 CompanyName列和ContactName列的值。通过BeginEdit和EndEdit来缓存对行的修改,还可调用 CancelEdit为取消修改。

    判断某列是否为空值:

    DataRowdr=ds.Tables["Customers"].Rows.Find("aaa");

    if(dr.IsNull("ContactName");

        ..

    else

        dr["ContactName"]=DBNull.Value

    这里判断ContactName列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。

    删除DataRow:

    有两种方法可以删除DataRow,Delete方法和Remove方法和RemoveAt方法。其区别是Delete方法实际上不是从 DataTable 中删除掉一行,而是将其标志为删除,仅仅是做个记号,而Remove方法则是真正的从DataRow中删除一行,RemoveAt方法是根本行的索引来删 除。列:

    DataRowdr=ds.Tables["table"].Rows.Find("a");

    ds.Tables["table"].Remove(dr);

    ds.Tables["table"].Remove(index);

    dr 为"a"所在的行,查出后将其删除,index为 "a"所在的索引号。关于DataSet中的其用法,参照MSDN

    DataRowdr=ds.Tables["Customers"].Rows.Find("aaa");

    if(dr.IsNull("ContactName");

        ..

    else

        dr["ContactName"]=DBNull.Value

    这里判断ContactName列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。

    usingSystem.Data;

    usingSystem;

    usingSystem.Windows.Forms;

    classDataT

    {

        static DataTable dt;// = new DataTable();

        static DataSet ds;

        static void method1()

        {

            dt = new DataTable("Name");

            ds = new DataSet();

            dt.Columns.Add(newDataColumn("ID", typeof(Int32)));

            dt.Columns.Add(newDataColumn("Name", typeof(string)));

            dt.Columns.Add(newDataColumn("Sex", typeof(string)));

            dt.Columns.Add(newDataColumn("Addr", typeof(string)));

        }

        static void add(int id,string name,stringsex,string addr)

        {

            DataRow dr = dt.NewRow();

            dr["id"] = id;

            dr["Name"] = name;

            dr["Sex"] = sex;

            dr["Addr"] = addr;

            dt.Rows.Add(dr);

        }

        static void Main()

        {

            DataT DT = new DataT();

            method1();

            add(100,"Join","Male","北京");

            add(101,"Lily","feMale","北京");

            add(102,"JIM","Male","北京");

            ds.Tables.Add(dt);

            foreach(DataRow dr in dt.Rows)

            {

                MessageBox.Show(dr["ID"].ToString()+ " " + dr["Name"].ToString() + " " +dr["Sex"].ToString() + " " +dr["Addr"].ToString(),"Message");

                Console.WriteLine(dr["ID"].ToString()+ " " + dr["Name"].ToString()+ " " +dr["Sex"].ToString() + " " +dr["Addr"].ToString());

            }

            Try

            {

                foreach(DataTable dt2 in ds.Tables)

                foreach(DataRow dr in dt2.Rows)

                Console.WriteLine(dr["ID"].ToString()+ " " + dr["Name"].ToString() + " " + dr["Sex"].ToString()+ " " + dr["Addr"].ToString());

            }

            catch(Exception ex)

            {

                Console.WriteLine("dkfjksdjfk");

            }

        }

    }

  • 相关阅读:
    PAT (Advanced Level) 1060. Are They Equal (25)
    PAT (Advanced Level) 1059. Prime Factors (25)
    PAT (Advanced Level) 1058. A+B in Hogwarts (20)
    PAT (Advanced Level) 1057. Stack (30)
    PAT (Advanced Level) 1056. Mice and Rice (25)
    PAT (Advanced Level) 1055. The World's Richest (25)
    PAT (Advanced Level) 1054. The Dominant Color (20)
    PAT (Advanced Level) 1053. Path of Equal Weight (30)
    PAT (Advanced Level) 1052. Linked List Sorting (25)
    PAT (Advanced Level) 1051. Pop Sequence (25)
  • 原文地址:https://www.cnblogs.com/zeroone/p/2541299.html
Copyright © 2011-2022 走看看