处理ADO.NET标准化注意问题
创始人
2024-06-16 14:31:16
0

章简明扼要的进行说明。针对ADO.NET标准化以及他的更多功能,还有一些功能请参照微软官网发布的实时消息,那上面讲述了一些你知道和不知道的内容,欢迎大家进行访问。

粗看起来,ADO.NET提供的模型是零散的,因为它没有包含一个通过的对象集,来处理多种不同类型的数据库。尽管不同的.NET数据提供者使用不同的类,但所有提供者都是采用同一方法进行标准化的。说得更明确一点,就是每个提供者都是基于相同的基类和接口集。例如,每个连接对象都执行IDbConnection接口,这些接口定义了核心的方法,如Open()、Close()。这个标准化保证每个连接类以同样的方式工作,并且向用户提供的核心属性和方法集是一样的。

在可视的界面之后,不同的提供者使用完全不同的底层调用和API。举个例来说,ADO.NET标准化SQL Server提供者使用私有的TDS(Tabular Data Stream)协议来与服务器通信。这个模型的好处并不是显而易见的,但它们很重要:

因为每个提供者使用相同的接口和基类,你可以编写通用的数据访问代码(只需一点点的努力),而不是需要针对具体的提供者类编写代码。你将在“Provider-Agnostic Code”一节中看到这个技术所起的作用。

由于每个提供者的实现是完全分离的,ADO.NET标准化可以使用私有的优化措施(这与ADO模型不同。在ADO中,ADO.NET标准化每个数据库调用需要在到达底层数据库驱动前要使用通过的层来进行过滤)。另外,自定义提供者能够添加非标准的功能,扩展在其它提供者中的不足(如SQL Server能够执行XML查询)。

ADO.NET也有另一个标准的层:DataSet。DataSet是一个能满足所有要求的数据容器,这些数据来自于一个数据源的一个或多个表。DataSet非常通用,换句话说,自定义提供者不需要定义DataSet类的自定义版本。无论你使用哪种数据提供者,你都能够以同样的方法提取数据和将数据放入未连接的DataSet。ADO.NET标准化这样就使得数据获取代码和数据处理代码分离开来。如果你改变了底层的数据库,你只需要改变数据获取代码,但如果你使用的DataSet和你的信息具有相同的结构,你就不需要改变数据处理的方法。

提示:下一章将对DataSet进行详细介绍,你将学到如何使用ADO.NET执行直接的、基于连接的访问的基本原理。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...