ODBC与OLEDB
通常,软件应用程序是用特定的编程语言(如Java、C#等)编写的,而数据库则接受其他特定于数据库的语言(如SQL)的查询。因此,当软件应用程序需要访问数据库中的数据时,需要一个能够相互翻译语言(应用程序和数据库)的接口。否则,应用程序程序员需要学习并在其应用程序中结合特定于数据库的语言。ODBC(开放数据库连接)和OLEDB(对象链接和嵌入,数据库)是解决这一特定问题的两个接口。ODBC是一个平台、语言和操作系统无关的接口,可用于此目的。OLEDB是ODBC的后续产品。
什么是ODBC?
ODBC是访问数据库管理系统(DBMS)的接口。ODBC是由SQL Access Group在1992年开发的,当时数据库和应用程序之间没有标准的通信介质。它不依赖于特定的编程语言、数据库系统或操作系统。程序员可以使用ODBC接口编写应用程序,这些应用程序可以从任何数据库查询数据,无论它运行的环境或使用的DBMS类型如何。
由于ODBC驱动程序充当应用程序和数据库之间的转换器,ODBC能够实现语言和平台的独立性。这意味着应用程序不再需要知道特定于数据库的语言。相反,它只知道并使用ODBS语法,驱动程序将用它能理解的语言将查询转换到数据库中。然后,以应用程序可以理解的格式返回结果。ODBC软件API可以用于关系数据库系统和非关系数据库系统。将ODBC作为应用程序和数据库之间的通用中间件的另一个主要优点是,每次数据库规范更改时,软件都不需要更新。只有更新ODBC驱动程序就足够了。
什么是OLEDB?
OLEDB是微软开发的数据API。它允许从大范围的数据源访问数据。它是使用微软的COM(组件对象模式)实现的。OLEDB被认为是ODBC的后继产品,与ODBC相比,它可以处理更高级别的数据源。本质上,OLEDB将ODBC功能扩展到非关系数据库(例如对象数据库和电子表格)。这意味着,OLEDB可以与不使用SQL的数据库一起使用。OLEDB是作为Microsoft数据访问组件(MDAC)的一部分开发的。
ODBC和OLEDB有什么区别?