使用速度更快的OLEDB取代ODBC连结

仍旧在使用ODBC系统或文件DSN连接数据库吗?请用速度更快的OLEDB提供者技术取代DSN连接数据库,不必再恳求你的ISP(或你的数据库管理员/Web管理员)为你创建系统DSN,也不必因为移动文件而修改配置。

OLEDB处于ODBC层和应用之间。对于ASP页面来说,ADO是OLEDB上面的一种“应用”。ADO调用首先发送给OLEDB,然后才被发送给ODBC层。但是你也可以直接连接到OLEDB层,而且如果你这么做了,你就会看到性能的进一步提升。那么,如何才能直接连接到OLEDB呢?

如果你使用的是SQL Server 7,用下面的代码作为连接串:   
strConnString = "DSN='';DRIVER={SQL SERVER};" & _
                "UID=myuid;PWD=mypwd;" & _
                "DATABASE=MyDb;SERVER=MyServer;"

如果你想越过ODBC,通过OLEDB使用SQL Server,使用下面的语法:   
strConnString ="Provider=SQLOLEDB.1;Password=mypassword;" & _
               "Persist Security Info=True;User ID=myuid;" & _
               "Initial Catalog=mydbname;" & _
               "Data Source=myserver;Connect Timeout=15"

现在你或许想知道学习这种新的连接方法有什么好处。为什么不使用标准的使用DSN方法呢?按照Wrox在ADO 2.0 Programmer's Reference这本书中的测试结果,使用OLEDB连接和使用DSN连接性能差异如下表:
<table>
<th><td>SQL</td><td>Access</td></th>
<tr><td>项目 OLEDB DSN</td><td>项目 OLEDB DSN</td></tr>
<tr><td>连接时间: 18 82</td><td>连接时间: 62 99</td</tr>
<tr><td>迭代1000个记录的时间: 2900 5400</td><td>迭代1000个记录的时间: 100 950 </td></tr>
</table>

注:上述结果在ADO 2.0 Programmer's Reference这本书的232、233页。时间以毫秒计,迭代1000个记录的时间用服务器端游标计算(使用客户端游标时,OLEDB和DSN记录集迭代的性能差别不大)。

时间: 2024-09-19 20:38:10

使用速度更快的OLEDB取代ODBC连结的相关文章

初学者来认识OLEDB和ODBC的区别

ODBC(开放数据库互连):是Microsoft引进的一种早期数据库接口技术.它实际上是ADO的前身.早期的数据库连接是非常困难的.每个数据库的格式都不一样,开发者得对他们所开发的每种数据库的底层API有深刻的了解. 因此,能处理各种各样数据库的通用的API就应运而生了.也就是现在的ODBC(Open Database Connectivity), ODBC是人们在创建通用API的早期产物.有许多种数据库遵从了这种标准,被称为ODBC兼容的数据库. OLEDB(对象链接和嵌入数据库)位于ODBC

ASP中OLEDB和ODBC的区别

ODBC(开放数据库互连):是Microsoft引进的一种早期数据库接口技术.它实际上是ADO的前身.早期的数据库连接是非常困难的. 每个数据库的格式都不一样,开发者得对他们所开发的每种数据库的底层API有深刻的了解. 因此,能处理各种各样数据库的通用的API就应运而生了. 也就是现在的ODBC(Open Database Connectivity), ODBC是人们在创建通用API的早期产物. 有许多种数据库遵从了这种标准,被称为ODBC兼容的数据库. OLEDB(对象链接和嵌入数据库)位于O

OLEDB和ODBC的区别(优缺点)_数据库其它

ODBC是一种连接数据库的开放标准. ODBC(OpenDataBase Connectivity,开放数据库互连)是微软公司开放服务结构(WOSA,Windows OpenServices Architecture)中有关数据库的一个组成部分,它建立了一组规范,并提供了一组对数据库访问的标准API(应用程序编程接口).这些API利用SQL来完成其大部分任务.ODBC本身也提供了对SQL语言的支持,用户可以直接将SQL语句送给ODBC. 它本身就是为了是数据库的使用者不必考虑使用的是何种数据库而

ODBC 资料库连结函式库

本函式库共有 25 个函式 开放资料连结 (Open Database Connectivity, ODBC) 是连结资料库的共通介面.ODBC 是由微软主导的资料库连结标准,实作环境也以微软的系统最成熟. 在 UNIX 系统中,通常要使用其它厂商所提供的 ODBC 介面,有些 UNIX 厂商会自己提供 ODBC 介面 (如 SUN 有为 Solaris 提供 ODBC). ODBC 和资料库的查询采用 SQL 语言,这和大部份的资料库查询方式一样,这使得系统可以很容易和各种资料库沟通.当然,透

PHP如何透过ODBC来存取数据库

odbc|数据|数据库 使用的环境 先建立一个测试用的数据库 接着建立一个ODBC连结 再建个测试用的PHP Script 咱们来测试吧 使用的环境 本文件主要是在Win32的环境下作说明, 您需要的是台跑Windows 9x/NT/2000的计算机, 并装有任何一种web server和PHP3或PHP4, 且可正确执行PHP Script. 并有一种以上的SQL数据库软件, 例如:Access... 本文件以MS-Access数据库来作说明, 其它种的数据库端, 皆可以类似的方法来作ODBC

为什么在存储过程中用OLEDB方式不能返回记录集_ASP基础

为什么在存储过程中用OLEDB方式不能返回记录集?我曾写过一段程序,是对临时表操作的(主要功能是取出每种分类的TOP10条记录).该存储过程使用ODBC连接数据库时正常,能够得到正确的结果.但在使用oledb方式连接时,却不能返回记录集,而一旦操作返回记录集时就出现错误提示:ADODB.Recordset 错误 '800a0e78' The operation requested by the application is not allowed if the object is closed.

PHP如何透过ODBC来存取数据库_php基础

使用的环境 先建立一个测试用的数据库 接着建立一个ODBC连结 再建个测试用的PHP Script 咱们来测试吧 使用的环境 本文件主要是在Win32的环境下作说明, 您需要的是台跑Windows 9x/NT/2000的计算机, 并装有任何一种web server和PHP3或PHP4, 且可正确执行PHP Script. 并有一种以上的SQL数据库软件, 例如:Access... 本文件以MS-Access数据库来作说明, 其它种的数据库端, 皆可以类似的方法来作ODBC连结. 先建立一个测试用

改进性能和样式的24个ASP 技巧_ASP基础

简介 技巧 1:在 Web 服务器上缓存常用数据 技巧 2:在 Application 或 Session 对象中缓存常用数据 技巧 3:在 Web 服务器磁盘上缓存数据和 HTML 技巧 4:避免在 Application 或 Session 对象中缓存非灵活组件 技巧 5:不要在 Application 或 Session 对象中缓存数据库连接 技巧 6:妙用 Session 对象 技巧 7:在 COM 对象中封装代码 技巧 8:晚点获取资源,早点释放资源 技巧 9:进程外的执行将牺牲可靠性

ASP技巧集锦(官方权威版)-2

技巧 技巧 3:在 Web 服务器磁盘上缓存数据和 HTML 有时,数据过多不能在内存中进行缓存."过多"是一种定性的判断:它取决于打算消耗的内存量,还有缓存项的数量和这些项的检索频率.总之,如果有过多的数据要在内存中缓存,请考虑以文本或 XML 文件的形式,在 Web 服务器的硬盘上缓存数据.可以将在磁盘上缓存数据和在内存中缓存数据组合起来,为站点建立最优的缓存策略. 注意,在度量单个 ASP 页的性能时,在磁盘上检索数据不一定比从数据库中检索数据快.但是,缓存减轻了数据库和网络的负