当前位置: 首页 > 图文教程 > 网络编程 > ASP > 使用速度更快的OLEDB取代ODBC连结

ASP
生成像资源管理器一样的树形目录
将连接数据库的代码隐藏在DLL中
ASP中从数据库读取二进制文件数据代码
asp查询xml的代码,实现了无刷新、模糊查询功能
一个asp函数, 解决SQL Injection漏洞
在ASP中利用COM组件开发Web应用程序
关于如何利用COM+,来提高ASP执行权限的问题!
升级MD5.ASP,打造完全动态不重复的安全加密代码
ASP安全检测与过滤函数SafeCheck
在ASP中,用JScript脚本实现分页的另类办法
查看服务器Application/Session变量工具
自己写的一个简单ASP调用存储过程查询
ASP登陆验证页应做的安全问题
使用ASP与javascript配合实现多个复选框数据关联显示
Windows 2003下不注册组件用ASP发邮件
数据分页方法新思路,速度非常快!
ASP程序中同一个用户不允许同时登陆两次
分栏显示记录集的表格演示,并实现了分页
关于Adodb.Stream的写数据库数据到客户端文件的实践
将ASP的Debug变得简单的两个函数

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 77 ::
收藏到网摘: n/a

  仍旧在使用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记录集迭代的性能差别不大)。