ADO与ADO.NET的那点事儿

06月 14th, 2008

ado与ado.net

ado与ado.net既有相似也有区别,他们都能够编写对数据库,需要一种新的架构来提供这种应用和数据源之间的无缝连接,基于com(component object model)的ole db应运而生了。

ado – 基于ole db之上的ado更简单、更高级、更适合visual basic程序员,同时消除了ole db的多种弊端,取而代之是微软技术发展的趋势。

ado与ado.net对照
在开始设计.net体系架构时,微软就决定重新设计数据访问模型,以便能够完全的基于xml和离线计算模型。两者的区别主要有:

ado以recordset存储,而ado.net则以dataset表示。recordset看起来更像单表,如果让recordset以多表的方式表示就必须在sql中进行多表连接。反之,dataset可以是多个表的集合。ado 的运作是一种在线方式,这意味着不论是浏览或更新数据都必须是实时的。ado.net则使用离线方式,在访问数据的时候ado.net会利用xml制作数据的一份幅本,ado.net的数据库连接也只有在这段时间需要在线。

由于ado使用com技术,这就要求所使用的数据类型必须符合com规范,而ado.net基于xml格式,数据类型更为丰富并且不需要再做com编排导致的数据类型转换,从而提高了整体性能。

小结
ado.net为.net构架提供了优化的数据访问模型,和基于com的ado是完全两样的数据访问方式。

ado.net与ado存在着比较大的差异:
1.ado.net遵循更通用的原则,不那么专门面向数据库。ado.net集合了所有允许数据处理的类。这些类表示具有典型数据库功能(如索引,排序和视图)的数据容器对象。尽管ado.net是.net数据库应用程序的权威解决方案,但从总体设计上看,它不像ado数据模型那样以数据库为中心,这是ado.net的一大特点。
2.目前,ado.net提供了两种数据库访问类库:一种用于sql server 7.0 或更高版本,另一种用于其他所有您可能已经安装的ole db提供程序。在这两种情况下,您分别使用不同的类,但遵循相似的命名规则。除前缀,名称都是相同的。前一种情况前缀为sql,后一种情况则是oledb。同时,.net框架还提供了odbc .net的数据访问模式。odbc .net data provider是 .net 框架的增强组件,它可以访问原始的 odbc 驱动程序,就像 ole db .net data provider 可以访问原始的 ole db providers 一样。目前它仅在下列驱动程序中测试过:microsoft sql odbc driver,microsoft odbc driver for oracle,microsoft jet odbc driver。
3.ado.net提供了两个队形来处理从数据源中抽取数据,它们是dataset和datareader对象。前者是记录在内存中的缓存,您可以从任何方向随意访问和修改。后者是高度优化的对象,专为以仅向前方式滚动只读记录而设计。
4.ado.net统一了数据容器类编程接口,无论您打算编写何种应用程序,windows窗体,web窗体还是web服务,都可以通过同一组类来处理数据。不管在后端的数据源数sql server数据库,ole db,xml文件还是一个数组,您都可以通过相同的方法和属性来滚动和处理它们的内容。
5.在ado中,xml只不过是输入和输出格式。然而在ado.net中,xml是一种数据格式,提供了操作,组织,共享和传递数据的手段。

标签:, ,

相关日志


This entry was posted on 星期六, 06月 14th, 2008 at 10:11 pm and is filed under 程序设计. You can follow any responses to this entry through the RSS 2.0 feed. You can leave a response, or trackback from your own site.

Leave a Reply