转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
亲密接触ASP.Net(10)         ★★★★

亲密接触ASP.Net(10)

作者:闵涛 文章来源:闵涛的学习笔记 点击数:589 更新时间:2009/4/23 10:39:04
接上一节,我们这一节主要计论如何使用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的方法和属性有很多,功能也
很全,我想现在这里的所讲的功能,对一般的操作已经足够了。


[C语言系列]NET 中C#的switch语句的语法  [系统软件]托拽Explore中的文件到VB.net的窗口
[系统软件]Boost库在XP+Visual C++.net中的安装  [常用软件]新配色面板:Paint.Net3.0RC1官方下载
[常用软件]用内建的“Net Meeting”聊天  [VB.NET程序]Henry的VB.NET之旅(三)—共享成员
[VB.NET程序]Henry的VB.NET之旅(二)—构造与析构  [VB.NET程序]Henry的VB.NET之旅(一)—失踪的窗体
[VB.NET程序]在托盘上显示Balloon Tooltip(VB.NET)  [VB.NET程序]Henry手记-VB.NET中动态加载Treeview节点(二)
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台