分享
 
 
 

亲密接触ASP.Net(10)

王朝asp·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

接上一节,我们这一节主要计论如何使用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的方法和属性有很多,功能也

很全,我想现在这里的所讲的功能,对一般的操作已经足够了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有