浅谈DataSet

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"所在的索引号。

关于DataSet中的其用法,参照MSDN

Published At
Categories with 数据库类
comments powered by Disqus