|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
最近用ASP和MSSQL做了一个数据库应用, 开始一切顺利,但随着数据量的增加, 先后几次查询时出现timeout的问题. 参考Option Pack文档及社区内的文章, 现在问题都已解决(至少没又发现新的). 现把解决方式总结一下: 影响服务器产生超时的设置大致有: 1. Server.ScriptTimeout, 2. Connection对象的CommandTimeOut属性, 3. Command对象的CommandTimeOut属性, 4. IE浏览器的设置. Server.ScriptTimeout,默认值是90秒. 要增大它,在你的asp文件中加一句,如下: Server.ScriptTimeout=999, 将页面超时设为999秒. 最初我只设置Server.ScriptTimeout, 但仍会出现timeout错误,无论它的值设成都多大. 后在社区里看到一帖子,提到commandTimeout属性, 于是查看Option Pack文档,果然还有其他的timeout. Connection对象和Command对象都有个CommandTimeOut属性, 默认是30秒,假如你有一个耗时的查询或数据处理, 很轻易就超时了.要增大它,也很轻易,创建对象后, 设置它的属性,如下: con.CommandTimeOut = 999, 设为999秒,其中con是一Connection对象. 如设为零,将无限等待,没有这一timeout限制. Command对象不会继续Connection的这一属性, 所以对可能超时的Command也要单独设置CommandTimeout属性. 最后IE也有个超时设置,5分钟从服务器得不到数据,也超时. 这种情况可能很少遇到, 但当我把一10多万查询的结果保存为mdb文件时, 就碰到了.(至于保存的方式,请参看精华区中的一篇帖子.) 解决方式:(原文请参照微软KB中的Q181050) 1. IE要4.01 sp1以上版本. 2. 在注册表中HKEY_CURRENT_USERSoftwareMicrosoft WindowsCurrentVersionInternet Settings中 加一DWORD类型ReceiveTimeout,值设为比如8个9. 3. restart computer. 返回类别: 教程 上一教程: 用ASP统计用户在站点的停留时间(2) 下一教程: REMOTE SCRIPT文档(转载自微软)(二) 您可以阅读与"ASP中有关TIMEOUT超时的体会"相关的教程: · ASP中有关timeout超时的体会 · ASP与Oracle连接时的TNS错误 · 使用SERVER.SCRIPTTIMEOUT来减少ASP意外错误而使务器瘫痪 · ASP中和星期有关的自定义函数 · ASP+JS时的符号处理 |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |