• DataSet及DataTable用法详解


    DataSet是ADO.NET开发人员为方便数据处理开发出来的,是数据的集合,是为解决DataReader的缺陷设计的,DataReader数据处理速度快,但它是只读的, 而且一旦移到下一行,就不能查看上一行的数据,DataSet则可以自由移动指针。DataSet的数据是与数据库断开的。 DataSet还可用于多层应用程序中,如果应用程序运行在中间层的业务对象中来访问数据库,则业务对象需将脱机数据结构传递给客户应用程序。
      DataSet的功能:浏览、排序、搜索、过滤、处理分级数据、缓存更改等。还可以与XML数据互换。DataSet中可包括多个 DataTable,可将多个查询结构存到一个DataSet中,方便操作,而DataTable中又包括多个DataRow、DataColumn,可通过这些DataRow、DataColumn来查看、操作其中的数据,而需将操作结果返回给数据库的话,则可以调用DataAdapter的 Update方法。
      DataSet的操作:
    DataSet ds=new DataSet();
    DataTable dt=new DataTable("newTable");
    ds.Tables.Add(dt);
    DataSet ds=new DataSet();
    DataTable dt=ds.Tables.Add("newTable");
    上述两种方法都可以在DataSet中添加一个DataTable,看需要而进行选择。添加DataTable后,需向其中添加行和列。
    DataSet ds=new DataSet();
    DataTable dt=ds.Tables.Add("newTables");
    DataColumn col=dt.Columns.Add("newColumn",typeof(int));
    col.AllowDBNull=false;
    col.MaxLength=4;
    col.Unique=true;

    上述代码向DataSet中的DataTable中添加名为”newColumn”,类型为int且不为空,最大长度为4和唯一性为真的列。
    dt.PrimaryKey=new DataColumn[] {dt.Columns["ID"]}
    这段代码是继续上面代码的,为一个DataTable中添加一个主键列,主键列是一个数据组,如有多个主键,只需在数组中添加一个列即可。如下:
    dt.PrimaryKey=new DataColumns[] {dt.Columns["OrderID"],dt.Columns["ProductID"]}
    添加外键:
    ForeignKeyConstraint fk;
    fk=new ForeignKeyConstraint(ds.Tables["Customers"].Columns["CustomerID"],ds.Tables["Orders"].Columns["CustomerID"]);
    ds.Tables["Orders"].Constraints.Add(fk);
    //上述代码假如已经为Cusomers表和Orders创建了主键,此句为添加外键约束。
    上述是根据Customers表和Orders表的CustomerID来创建约束。
    下面介绍修改DataRow中的内容:
    DataRow dr=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为取消修改。
    判断某列是否为空值:
    DataRow dr=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方法是根本行的索引来删除。列:
    DataRow dr=ds.Tables["table"].Rows.Find("a");
    ds.Tables["table"].Remove(dr);

    ds.Tables["table"].Remove(index);
    //dr 为"a"所在的行,查出后将其删除,index为 "a"所在的索引号。

    DataTable   dt   =   new   DataTable("Staff");  
       
      DataColumn   dc;  
      dc   =   new   DataColumn("ID",   System.Type.GetType("System.Int32"));  
      dt.Columns.Add(dc);  
       
      dc   =   new   DataColumn("BeginDate",   System.Type.GetType("System.DateTime"));  
      dt.Columns.Add(dc);  
       
      dc   =   new   DataColumn("EndDate",   System.Type.GetType("System.DateTime"));  
      dt.Columns.Add(dc);  
       
      dc   =   new   DataColumn("Company",   System.Type.GetType("System.String"));  
      dt.Columns.Add(dc);  
       
      dc   =   new   DataColumn("Department",   System.Type.GetType("System.String"));  
      dt.Columns.Add(dc);  
       
      dc   =   new   DataColumn("Manager",   System.Type.GetType("System.String"));  
      dt.Columns.Add(dc);  
       
      dc   =   new   DataColumn("Telephone",   System.Type.GetType("System.String"));  
      dt.Columns.Add(dc);  
       
      DataRow   dr;  
       
      dr   =   dt.NewRow();  
      dr["ID"]   =   1;  
      dr["BeginDate"]   =   System.DateTime.Today;  
      dr["EndDate"]   =   System.DateTime.Today;  
      dr["Company"]   =   "××××";  
      dr["Department"]   =   "××××";  
      dr["Manager"]   =   "××";  
      dr["Telephone"]   =   "654321";  
      dt.Rows.Add(dr);  
       
      dgWork.DataSource   =   dt;  
      dgWork.DataBind();

  • 相关阅读:
    论文阅读笔记(七十二)【ICMR2020】:Compact Network Training for Person ReID
    论文阅读笔记(七十一)【CVPR2018】:Harmonious Attention Network for Person Re-Identification
    论文阅读笔记(七十)【CVPR2021】:Combined Depth Space based Architecture Search For Person Re-identification
    论文阅读笔记(六十九)【CVPR2021】:BiCnet-TKS: Learning Efficient Spatial-Temporal Representation for Video Person Re-Identification
    论文阅读笔记(六十八):图文跨模态行人检索(3篇)
    (一万小时计划)二月二日总结
    (一万小时计划)一月二十三日总结
    (一万小时计划)一月二十日总结
    (一万小时计划)一月二日总结
    (一万小时计划)十二月二十二日总结
  • 原文地址:https://www.cnblogs.com/qzbnet/p/2666368.html
Copyright © 2020-2023  润新知