zoukankan      html  css  js  c++  java
  • DataSet 的用法(转)

    浅谈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");

            }

        }

    }

  • 相关阅读:
    帧间编码的预测自适应量化系数扫描排序
    调试vp8编码和解码程序
    WPF学习——制作一个简单的录入界面(2):用C#编程实现所有控件的功能
    自适应变异引用(AWR)方法(an adaptive warped reference (AWR) method )
    vp8编解码调试(环境vs2005)
    加油
    开始工作blog了
    vs2010编译vp8
    WPF学习——制作一个简单的录入界面(1): 添加需要的控件
    JPEG编码
  • 原文地址:https://www.cnblogs.com/zhengqian/p/8241170.html
Copyright © 2011-2022 走看看