首先,我们来了解数据库连接技术中的两个经典方案:ODBC(开放数据库互连)与OLEDB。ODBC由微软早期推出,作为ADO的前身标准。在ODBC诞生之前,数据库连接极为繁琐:每种数据库都拥有独特的格式和底层API,开发者需要为不同数据库学习完全不同的接口。因此,一个能够兼容多种数据库的通用API成为迫切需求,ODBC应运而生。此后,许多数据库开始遵循这一标准,成为所谓的“ODBC兼容数据库”。
接下来介绍OLEDB(对象链接和嵌入数据库)。OLEDB位于ODBC层与应用程序之间。在ASP页面中,ADO作为运行在OLEDB之上的“应用程序层”。ADO调用会先发送至OLEDB,再由OLEDB转发给ODBC处理。然而,你也可以选择直接连接OLEDB层——这样做能显著提升服务器端游标(Recordset默认游标,也是使用最频繁的一种)的性能。
现在来看通过ODBC连接数据库的具体方法。ODBC提供三种DSN(数据源名称),其区别简明:用户DSN仅限当前用户使用;系统DSN与文件DSN的区别在于连接信息的存储位置——系统DSN保存在ODBC存储区,而文件DSN则存放在文本文件中。关于创建步骤此处不再赘述,直接展示用法。
A. SQL Server
使用系统DSN:
connstr="DSN=dsnname; UID=xx; PWD=xxx;DATABASE=dbname"
使用文件DSN:
connstr="FILEDSN=xx;UID=xx; PWD=xxx;DATABASE=dbname"
此外,也可以使用连接字符串(无需创建DSN):
connstr="DRIVER={SQL SERVER};SERVER=servername;UID=xx;PWD=xxx"
B. Access
使用系统DSN:
connstr="DSN=dsnname" (或 connstr="DSN=dsnname;UID=xx;PWD=xxx")
使用文件DSN:
connstr="FILEDSN=xx"
使用连接字符串(无需创建DSN):
connstr="DRIVER={Microsoft Access Driver};DBQ=d:\abc\abc.mdb"
接下来,我们来看使用OLEDB连接数据库的方法:
A. SQL Server
connstr="PROVIDER=SQLOLEDB; DATA SOURCE=servername;UID=xx;PWD=xxx;DATABASE=dbname"
B. Access
connstr="PROVIDER=MICROSOFT.JET.OLEDB.4.0; DATA SOURCE=c:\abc\abc.mdb"
值得注意的是,OLEDB对ODBC具有良好的兼容性——它允许OLEDB访问现有的ODBC数据源。这一优势十分显著:ODBC比OLEDB问世更早、应用更广泛,因此可用的ODBC驱动程序数量远超过OLEDB。这意味着即便没有专用的OLEDB驱动程序,也能立即访问原有的数据系统。
这里有一个关键区别:提供者(Provider)位于OLEDB层,而驱动程序(Driver)位于ODBC层。若要使用ODBC数据源,需先启用针对ODBC的OLEDB提供者,再由其调用相应的ODBC驱动程序。如果不希望经过ODBC,则可以直接使用本地提供者(Native Provider)。简而言之,使用ODBC提供者会增加一层开销。在访问相同数据时,针对ODBC的OLEDB提供者通常比本地OLEDB提供者性能略慢。

