C#  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中包含多个DataTable,一个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["UserList"].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()方法,恢复DataSet中的数据。注意这里恢复是在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中的数据相比较,对不相同的地方进行更新。

java的dataset怎么用,C# DataSet的基本用法相关推荐

  1. dataset存入mysql_将dataset写入数据库

    最近在将excel中的文件导入到数据库中,用程序进行编写,由于数据量较大所以速度很慢,后来采用了SqlBulkCopy类,解决了速度的问题,我就insert语句,sqldataadapter.upda ...

  2. e.target.dataset和e.currentTarget.dataset

    作用: e.target.dataset与e.currentTarget.dataset的作用:获取标签中定义的值,定义方法 data-*=某个值 区别: e.target.dataset是指获取当前 ...

  3. ExecuteNonQuery、ExecuteScalar、Dataset、ExecuteReader的不同意思和用法

    ExecuteNonQuery.ExecuteScalar.Dataset.ExecuteReader的不同意义和用法 1. ExecuteNonQuery 方法执行 一个非查询语句( Update ...

  4. 详解Java多线程编程中LockSupport类的线程阻塞用法

    转载自  详解Java多线程编程中LockSupport类的线程阻塞用法 LockSupport类是Java6(JSR166-JUC)引入的一个类,提供了基本的线程同步原语.LockSupport实际 ...

  5. java集合框架中contains(),containsKey()和containsValue()的用法

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. java集合框架中contains(),containsKey()和containsValue()的 ...

  6. Java 枚举(enum) 详解7种常见的用法<详细>

    JDK1.5引入了新的类型--枚举.在 Java 中它虽然算个"小"功能,却给我的开发带来了"大"方便. 大师兄我[大师兄]又加上自己的理解,来帮助各位理解一下 ...

  7. java中的感叹号是_[Java教程]javascript中的2个感叹号的用法

    [Java教程]javascript中的2个感叹号的用法 0 2014-04-15 19:00:09 !!是逻辑"非非",即是在逻辑"非"的基础上再" ...

  8. Java类中this关键字和static关键字的用法详解

    今天给大家总结介绍一下Java类中this关键字和static关键字的用法. 文章目录 this关键字用法: 1:修饰属性,表示调用类中的成员变量 2:this修饰方法 3:this表示当前对象的引用 ...

  9. Java 枚举(1): 详解7种常见的用法

    目录 用法一:常量 用法二:switch 用法三:向枚举中添加新方法 用法四:覆盖枚举的方法 用法五:实现接口 用法六:使用接口组织枚举 用法七:关于枚举集合的使用 JDK1.5引入了新的类型--枚举 ...

  10. java集合框架中contains(),containsKey()和containsValue()的用法:

    java集合框架中contains(),containsKey()和containsValue()的用法: List集合的contains()方法用于判断集合中包不包含某个元素,返回值是boolean ...

最新文章

  1. [20180412]订阅+镜像切换
  2. Pycharm如何设置自定义背景颜色
  3. Quartz Java resuming a job excecutes it many times--转
  4. hdu 4503 湫湫系列故事——植树节
  5. 板邓:【WordPress文件解读】wp-config.php
  6. 自动调试自动编译五分钟上手
  7. CodeForces 486C Palindrome Transformation 贪心+抽象问题本质
  8. python读取xls文件_从python中的xls读取unicode
  9. 字符串怎样实例化成对象
  10. SQL Server Join方式
  11. 英语在线听力翻译器_在线翻译英语软件推荐 在线翻译英语软件哪个好
  12. Android 投屏集成记录
  13. Android 自定义viewGroup实现淘宝二楼及处理多指触控事件
  14. django html 插入网页背景图片
  15. idea 常用配置介绍(一)
  16. 程序员如何提高自己的逻辑思维和技术水平
  17. Ubuntu: Host Controller not enabled 报错
  18. 分布式文件系统—FastDFS-6.0.6搭建使用
  19. 微信小程序----封装request以及对接口进行模块化
  20. 西部数码网站管理助手 mysql_西部数码网站管理助手开启自定义伪静态教程

热门文章

  1. Android作业四
  2. IGS精密星历及其下载(自PureSky_Memory的博客)
  3. 【计算机网络】网络通信基础
  4. 解析java文件_使用JDK的Parser来解析Java源代码
  5. 易语言服务器卡密验证,想写一个关于辅助登录卡密的软件。 问题:易语言如何会做一个输入正确卡密才可以登入界面的...
  6. php源码 学校版 cms,闪灵CMS学校建站系统(含小程序)
  7. go模板引擎生成html,goweb-模板引擎
  8. 水果编曲软件除了做电音还能做什么
  9. 开设进口零食店的项目
  10. 【GitHub通过ssh方法下载详细配置过程】