DataSet DataTable DataReader dataAdapter区别_第1页
DataSet DataTable DataReader dataAdapter区别_第2页
DataSet DataTable DataReader dataAdapter区别_第3页
DataSet DataTable DataReader dataAdapter区别_第4页
DataSet DataTable DataReader dataAdapter区别_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、DataSet DataTable DataReader dataAdapter区别DataSet是用来做连接sql的一种方法,意思是把数据库的副本存在应用程序里,应用程序开始运行时,把数据库相关数据保存到DataSet.DataTable表示内存中数据的一个表.常和DefaultView使用获取可能包括筛选视图或游标位置的表的自定义视图。DataReader对象是用来读取数据库的最简单方式,它只能读取,不能写入,并且是从头至尾往下读的,无法只读某条数据,但它占用内存小,速度快DataAdapter对象是用来读取数据库.可读取写入数据,某条数据超着强,但它占用内存比dataReader大,速度

2、慢dataset表示一个数据集,是数据在内存中的缓存。可以包括多个表DatSet 连接数据库时是非面向连接的。把表全部读到Sql中的缓冲池,并断开于数据库的连接datareader 连接数据库时是面向连接的。读表时,只能向前读取,读完数据后有用户决定是否断开连接。分布式系统的数据可能会用dataset做数据载体,因为dataset是保存数据的数据结构,而DataReader不承担保存数据的责任,它只负责从数据源读取数据到本地而已,它不是数据结构,而是网络通讯组件的高层封装。DataAdapter也只是使用DataReader从数据源读取数据并Add到dataset保存起来而已。假如我们单独使用

3、DataReader也可以把数据写入到业务类或者dataset里。那只是根据业务需要而选择不同的数据载体而已。实际上我们从数据库获得数据都会通过DataReader,只不过DataAdapter把这一切都封装起来了dataset 和datareader对象有什么区别?DataSet可以离线处理,前后滚动.DataReader不能离线处理,且是只读的向前的,不过速度明显会很快DataSet可以存储数据库各种对象的,比如表触发器等,而DataReader只能存储游标记录DataSet可以更新回原来的数据库,DataReader不行;DataSet可以FORWORD PREVIUS,而DataRea

4、der只能FW; DataReader类似一个只能向前的游标记录集DataSet 叫数据集!是ADO.net相对与ADO实现断开式数据库连接性的主要体现!DateReader是一个客户端的只向前游标,两者的应用领域不同!读取数据后!如果要进行比较频繁的改动,可以使用DataSet,并且DataSet也支持串行化,可与xslt结合!进行web开发!DataReader 则偏向于快速读取数据!针对数据量比较大的数据可能应用的更加频繁点!<三>ADO.NET提供以下两个对象,用于检索关系数据并将其存储在内存中:DataSet和DataReader。DataSet提供一个内存中数据的关系表

5、示形式,一整套包括一些表在内的数据(这些表包含数据、对数据进行排序并约束数据,以及表之间的关系。DataReader提供一个来自数据库的快速、仅向前、只读数据流。当使用DataSet时,经常会利用DataAdapter(也可能是CommandBuilder与数据源进行交互。当使用DataSet时,也可以利用DataView对DataSet中的数据应用排序和筛选。也可以从DataSet继承,创建强类型DataSet,用于将表、行和列作为强类型对象属性公开。下列主题包括的信息涉及:使用DataSet或DataReader的最佳时机、如何优化访问它们所包含数据、以及如何优化使用DataAdapter

6、(包括CommandBuilder和DataView的技巧。DataSet与DataReader当设计应用程序时,要考虑应用程序所需功能的等级,以确定使用DataSet或者是DataReader。要通过应用程序执行以下操作,就要使用DataSet:r 在结果的多个离散表之间进行导航。r 操作来自多个数据源(例如,来自多个数据库、一个XML文件和一个电子表格的混合数据的数据。r 在各层之间交换数据或使用XML Web服务。与DataReader不同的是, DataSet能传递给远程客户端。r 重用同样的记录集合,以便通过缓存获得性能改善(例如排序、搜索或筛选数据。r 每条记录都需要执行大量处理。

7、对使用DataReader返回的每一行进行扩展处理会延长服务于DataReader的连接的必要时间,这影响了性能。r 使用XML操作对数据进行操作,例如可扩展样式表语言转换(XSLT转换或XPath查询。对于下列情况,要在应用程序中使用DataReader:r 不需要缓存数据。r 要处理的结果集太大,内存中放不下。r 一旦需要以仅向前、只读方式快速访问数据。注填充DataSet时,DataAdapter使用DataReader。因此,使用DataAdapter 取代DataSet提升的性能表现为节省了DataSet占用内存和填充DataSet需要的循环。一般来说,此性能提升只是象征性的,因此,

8、设计决策应以所需功能为基础。< 四>经常听到有人问这个问题:“在ASP.NET Web应用程序中我应该用DataReader类还是DataSet类呢?”在很多文章以及新闻组的贴子中我经常看到这样的误解,即认为DataReader(SqlDataReader或OleDbDataReader 的缩写比DataSet好。有时候我也会看到相反的说法。事实上,Microsoft 创建了这两个数据存取类是因为它们都是我们所需要的。每个类都有其优点和不足,你可以根据应用环境来选择用哪一个。本文就两者的选择问题做了很清楚的讲述,可以让你在运用ASP.NET时,在选择DataReader类或Data

9、Set类的方面得到一些指南。在基于客户端的Windows Form应用程序环境下,这些规则可能会改变。我在做这些讲述时,假设你已经用过DataReader和DataSet类了,并对它们很熟悉。运用DataReader类下面就是运用DataReader类的理想条件:你读取的数据必须是新的,所以在每次需要数据的时候,你都必须从数据库读取。创建一个DataReader类不会消耗很多内存,不过随着负荷的增加,DataSet上的性能也会很快地提高(参考资源中 Visual Studio Magazine 中的文章) 。 你对每行数据的需求很简单。该情况的最好的例子就是简单地将 DataReader 绑定

10、到一个 Web 控件,如 DataGrid 或 DropDownList。 你只需要从数据库中以只向前的(forward-only 、只读的形式来存取 XML 数 据。在这种情况下,你可以用 SQLCommand 对象的 ExcecuteXmlReader(方 法来得到一个 XmlReader 类(相当于 XML 版的 DataReader) 。这就需要一个 运用 FOR XML 子句的 SQL Server 查询,或者一个包含有效 XML 的 ntext 字 段。 你计划对数据库进行几个重复的调用,来读取一小块信息。在这种情况下,我们 前面提到过的性能数据会有更大的提高。 的确,使 Data

11、Set 类更强大的许多功能只适用于基于客户端的 Windows Form 应用程序,比如在多个表之间建立关系的功能。在很多情况下,DataSet 类都比 DataReader 类更有优势, 而且在有些情况下, 你根本就不能用 DataReader 类。 运用 DataSet 类 在下面的情况,你应该考虑运用 DataSet 类: 你构建了一个 Web service,它 运用的数据是你作为返回值读取的数据。 因为 DataReader 类必须保持到数据库 的连接,所以它们不能被序列化到 XML 中,也不能被发送给一个 Web service 的调用者。 你需要排序或筛选数据。在运用一个 Dat

12、aView 对象(呈现为 DataTable 类的 DefaultView 属性,它包含一个 DataSet 类)来排序或筛选数据前,我们先试 着用 SQL 查询(如 WHERE 和 ORDER BY 语句)来实现这些功能,并运用更轻 量级、更快的 DataReader 类。然而,有时侯用这种方法是不行的,或者当你需 要多次地对数据进行排序或筛选时就不能用 DataReader。 针对同一请求,你需要多次遍历数据。你只能在 DataReader 中循环一次。如果 你想将多个 ServerControl 类绑定到同一个数据集, 那么选择 DataSet 就更好。 DataReader 类不能被绑

13、定到多个 ServerControl 类,因为它是只向前读取的。 在这种情况下,如果要使用 DataReader,必须从数据库读取两次数据。 你需要存储数据,而后续的页面请求可能会用到的这些数据。如果数据只被请求 它的专门的人使用,你可以将 DataSet 类保存在一个 Session 变量中。如果数 据可以被任何人访问,那么你可以将它保存在一个 Application 变量中,或保存 在 Cache 中 (我建议使用后一种方法, 因为它支持时间期限和回调 (callback)。 ) 因为 DataReader 类必须一直打开对数据库的连接,而且它一次只能保存一行 数据,所以它们不能在跨页面请

14、求中被保存。 你需要对一个结果集的每个元素实现特殊的、耗时的功能。例如,如果你从一个 数据库读取一列邮政编码,并想通过调用一个 Web service 来得到每个地区的 详细的天气状况信息,那么选择 DataSet 就会更好。这是因为,当你在用 DataReader 类时,在关闭 DataReader 类前,与数据库的连接不会被释放回 连接池。在数千页面请求之间潜在的一个很小的延时都会造成 Web 应用程序的 很高的访问量,从而就会消耗完可用的连接。相反,DataSet 可以在前端读取所 有的数据,并可以马上关闭与数据库的连接,将它返回到连接池,因此其它的页 面请求就可以用这个连接了。 你需要

15、在一个两维范例中加载并处理 XML 数据。DataSet 类对于 XML 很有用, 因为你可以将 DataView 用于 XML,对根本的数据进行排序和筛选,就同处理 一个数据库结果集一样。然而,需要注意的是在 System.Xml 名字空间中有很多 类,你可以将它们用于更复杂的 XML 操作。 你的数据源不是一个数据库。 虽然 OleDbDataReader 可以用于任何 OLEDB 数 据提供者(可能指向一个数据库,也可能不指向一个数据库) ,但 DataSet 对象 可以从一个 XML 文件直接加载数据,并动态地解释它的 schema。DataSet 类 也可以将 XML 数据写回一个数据流或一个文件。 从上面的讲述我们就可以看到, DataSet 类比 DataReader 类有更多的功能, 这 就可以让你在更多的情况下运用它们。但这并不意味着你总是在用 DataSet

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论