现在的位置: 首页 > 综合 > 正文

dataset一些用法

2012年11月07日 ⁄ 综合 ⁄ 共 3715字 ⁄ 字号 评论关闭

从数据库完成数据抽取后,DataSet就是数据的存放地,它是各种数据源中的数据在计算机内存中映射成的缓存,所以有时说DataSet可以看成是一个数据容器。同时它在客户端实现读取、更新数据库等过程中起到了中间部件的作用(DataReader只能检索数据库中的数据)。

dataset是数据集,数据集里包含datatable,还有数据表之间的关系等。
datatabl是数据表,它有列columns,行rows等。DataView是视图
DataView DV=ds.Tables["表名"].DefultView;
DataGrid1.DataSource=DV;

Dataset:数据集。一般包含多个DataTable,用的时候,dataset["表名"]等到DataTable
DataTable:数据表
SqlDataAdapter da=new SqlDataAdapter(cmd);
DataTable dt=new DataTable();
da.Fill(dt);

二:直接把数据结果放到datatable中,
SqlDataAdapter da=new SqlDataAdapter(cmd);
DataSet dt=new DataSet();
da.Fill(dt);

数据结果放到dataset中,若要用那个datatable,可以这样:dataset[0]
更常见的用法:
SqlDataAdapter da=new SqlDataAdapter(cmd);
DataSet dt=new DataSet();
da.Fill(dt,"table1");
用的时候:这样取datatable:

dataset["table1"]

DataTable表示内存中的一个表。
DataTable的创建
DataTable dt=new DataTable("tbAmount"); //创建DataTable
dt.Columns.Add("riqi",System.Type.GetType("System.String")); //创建DataTable的列的框架
//也可以用DataColumn dc=new DataColumn("riqi",System.Type.GetType("System.String")); dt.Columns.Add(dc);
dt.Columns.Add("bianm",System.Type.GetType("System.String"));
dt.Columns.Add("xAmount",System.Type.GetType("System.String"));
dt.Columns.Add("jPoints",System.Type.GetType("System.String"));

DataRow drw=dt.NewRow(); //创建一行
drw["riqi"]="2008-12-25"; //把数据加进行
drw["bianm"]="100007";
drw["xAmount"]="234";
drw["jPoints"]="900";
dt.Rows.Add(drw); //把行添加到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列是否为空,如果不是则为其赋空值,呵,很无厘头的做法,这里只为演示为列赋空值的做法。
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 ds = bll.GetEntProperty();
if (ds.Tables[0].Rows.Count > 0)
{
foreach (DataRow dr in ds.Tables[0].Rows)
{
ListItem listitem = new ListItem();
listitem.Text = dr["cName"].ToString();
listitem.Value = dr["iPharmacistTypeID"].ToString();
this.Items.Add(listitem);
}
}

 

 

 

int n = ds.Tables[0].Rows.Count;
string result = "";
if (n > 0)
{
for (int i = 0; i < n; i++)
{
result += ds.Tables[0].Rows[i]["iEnterpriseTypeID"].ToString() + ",";
}
}

抱歉!评论已关闭.