ODBC与ADO
通常,软件应用程序是用特定的编程语言(如Java、C#等)编写的,而数据库则接受其他特定于数据库的语言(如SQL)的查询。因此,当软件应用程序需要访问数据库中的数据时,需要一个能够相互翻译语言(应用程序和数据库)的接口。否则,应用程序程序员需要学习并在其应用程序中结合特定于数据库的语言。ODBC(开放式数据库连接)和oledb(对象链接和嵌入,数据库)是解决这个特定问题的两个接口。ODBC是一个平台、语言和操作系统无关的接口,可用于此目的。oledb是ODBC的继承者。ADO是oledb的包装器。
什么是ODBC?
ODBC是访问数据库管理系统(DBMS)的接口。ODBC是SQL Access Group在1992年开发的,当时数据库和应用程序之间还没有标准的通信媒介。它不依赖于特定的编程语言、数据库系统或操作系统。程序员可以使用ODBC接口编写应用程序,这些应用程序可以查询任何数据库中的数据,而不管它运行的环境是什么,也不管它使用的是什么类型的DBMS。
由于ODBC驱动程序充当应用程序和数据库之间的转换器,ODBC能够实现语言和平台的独立性。这意味着应用程序不再需要知道特定于数据库的语言。相反,它只知道并使用ODBS语法,驱动程序将用它能理解的语言将查询转换到数据库中。然后,以应用程序可以理解的格式返回结果。ODBC软件API可以用于关系数据库系统和非关系数据库系统。将ODBC作为应用程序和数据库之间的通用中间件的另一个主要优点是,每次数据库规范更改时,软件都不需要更新。只有更新ODBC驱动程序就足够了。
什么是ADO?
ADO是COM(组件对象模式)对象的集合,这些对象充当访问数据源中数据的接口。ADO是微软在1996年开发的,作为微软数据访问组件(MDAC)的一部分。ADO在用某种编程语言编写的应用程序和oledb(微软开发的数据API,ODBC的继承者)之间形成了一个中间件层。程序员可以使用ADO访问数据,而不必知道数据库的底层实现细节。虽然使用ADO不需要知道任何SQL,但是可以使用它执行SQL语句。
ODBC和ADO有什么区别?