ADO、OLE DB、ODBC 关系

来源:互联网 发布:it发展趋势 编辑:程序博客网 时间:2024/05/29 17:11

 本文转载自http://hi.baidu.com/wangzhangjiayi/blog/item/1f989ffb8e76208a59ee90bb.html

ADO的概念:ADO (ActiveX Data Objects) 是一个用于存取数据源的COM组件。它提供了编程语言和统一数据访问方式OLE DB的一个中间层。允许开发人员编写访问数据的代码而不用关心数据库是如何实现的,而只用关心到数据库的连接。访问数据库的时候,关于SQL的知识不是必要的,但是特定数据库支持的SQL命令仍可以通过ADO中的命令对象来执行。

 

        ODBC的概念:ODBC:开放数据库互连(ODBC)是Microsoft引进的一种早期数据库接口技术,开放数据库互连(Open Database Connectivity,ODBC)是微软公司开放服务结构(WOSA,Windows Open Services Architecture)中有关数据库的一个组成部分,它建立了一组规范,并提供了一组对数据库访问的标准API(应用程序编程接口)。这些API利用SQL来完成其大部分任务。

 

        OLE DB的概念:OLE DB(OLEDB)是微软的战略性的通向不同的数据源的低级应用程序接口。OLE DB不仅包括微软资助的标准数据接口开放数据库连通性(ODBC)的结构化问题语言(SQL)能力,还具有面向其他非SQL数据类型的通路。作为微软的组件对象模型(COM)的一种设计,OLE DB是一组读写数据的方法(在过去可能被称为渠道)。

       

个人鄙见:从上面我标出来的红色字体不难看出,ODBC和OLE DB都是应用程序接口,都是为了应用程序访问数据库定制的一组标准,而ODBC是曾经的数据库通信标准,而OLE DB是在一切对象化的趋势下,微软打算用它取代ODBC,OLEDB分两种:直接的OLEDB和面向ODBC的OLEDB,后者架构在ODBC上,这样没有自己的OLEDB提供者的数据库也可以使用OLEDB的特点了。OLEDB的效率要高于ODBC,而且OLEDB要包含ODBC。

 

        至于ADO:是一个应用程序层次的界面,它用oledb来与数据库通信 ,是应用程序和OLEDB中间的一层。为什么要添加这一层呢,开发人员直接使用OLEDB去和数据库通信不就可以了吗,因为OLEDB相对来说底层一些,直接操作它的难度也就大一些,所以微软为了开发人员的简洁性就推出了ADO,我觉得这里还和降低耦合有点关系。    

原创粉丝点击