亲密接触ASP.Net(10)
2024-07-10 12:55:25
供稿:网友
接上一节,我们这一节主要计论如何使用dataset,在数据库中增加、修改、删除一个数
据。
首先我们需要打开一个联结,我们的数据库还是用上一节的吧:)
string myconnstring = "driver={microsoft access driver (*.mdb)};
dbq=c:/test/test.mdb;";
string strcomm = "select * from userlist";
adoconnection myconnection = new adoconnection(myconnstring);
adodatasetcommand mycomm = new adodatasetcommand(strcomm,myconnection);
这里我们为了讲解方便,只在dataset存入一个表的内容:
dataset mydataset = new dataset();
mycomm.filldataset(mydataset,"userlist");
此时我们就获得了一个拥有userlist表数据的dataset。在讲解dataset之前,我们还需
要了解dataset的结构下面是dataset的结构树
dataset
relationscollection
extendedproperties
tablescollection
datatables
rows
columns
其它
由于我们研究的是datatable,其它的我们暂时不管他们。一个dataset中包含多个datat
able,一个datatable又包含有多个row,这就是我们操作dataset的基础啦:)
添加数据
添加一数据,从上面的列表中我们可以看出,其实就是添加一行row,这里我们也来演示
一下如何添加一行数据,我们程序一切以dataset为顶点,呵呵,如果tablescollection
,rowscollection下去的话,还有一些烦人的dt.acceptchanges这些方法的调用,很烦人
,还是一次搞定吧。
datarow dr=mydataset.tables["userlist"].newrow();
dr["username"] = "周讯";
dr["remark"] = "100";
dr["comment"] = "漂亮mm";
mydataset.tables.rows.add(dr);
第一行,我们建立一个新的数据行,它用来储存我们新加入的数据。然后我们在这个数
据行中加入我们需要的数据。dr["username"]表明是对username字段进行添加,你可以
使用dr[1]来添加信息,但是这需要我们事先知道字段在数据表的位置,而且在不知道数
据表结构的情况很难知道我们添加的数据的对应情况,所以还是用字段名为好。
最后我们使用rowscollection的add方法,将我们新建这一行加入到数据表中。
修改数据
知道如何添加数据后,修改数据也是很简单的事情了.
mydataset.tables["userlist"].rows[0]["username"]="飞刀大哥";
这样我们就修改了第一行数据中的username字段。
删除数据
删除数据,主要是使用rowscollection提供的delete方法,看下面的程序也是很简单的
事情啦:)
mydataset.tables["userlist"],rows[0].delete();
这一行数据就已经被删除了。
恢复数据
有时候我们添加/修改数据会出现错误,这时候,就需要恢复原来的数据。下面的程序,
显示如何判断是否有错误发生:
if(mydataset.haserrors)
{
mydataset.rejectchanges();
}
首先我们检查dataset中是否有错误发生,如果有就使用rejectchanges()方法,恢复dat
aset中的数据。注意这里恢复是在dataset中所有表以及表中datarow中的数据,也就是
在此交次操作的数据全部恢复。如果我们只需要恢复部分内容,我们可以使用datatable
或datarow的rejectchanges(),这里就不详细讲解了,使用方法和dataset一样,只是操
作的对像不同而已。
探测dataset是否有改动
我们在将dataset送交给数据库去保存去,我们需要看看这个dataset是否已经被改动了
。如果没有改动,我们也就没有必要去修改数据库了。
if(mydataset.haschanges)
{
//保存
}else{
//不进行任何操作
}
更新数据库
我们上面的操作,都只是针对dataset的,没有操作数据库,但是我们的目的还是要将数
据保存到数据中去,所以我们这里就需要调用datasetcommand的update方法。下面的程
序显示如何将dataset的数据交给数据库。
mycomm.update(mydataset);
很简单的一句,呵呵。这里要注意,如果一个dataset中包含有多个表,而我们只更新一
个,那我们就必须写明更新的数据表名:
mycomm.update(mydataset,"userlist");
当update方法被调用后,datasetcommand会将数据库中的数据与dataset中的数据相比较
,对不相同的地方进行更新。
对于dataset的操作,我们这里只讲这么多,其实dataset的方法和属性有很多,功能也
很全,我想现在这里的所讲的功能,对一般的操作已经足够了。