MSSQL数据库查询“超时时间已到……”的解决方案
当前位置:点晴教程→知识管理交流
→『 技术文档交流 』
问题描述
--------------------------------------------------------------------------------------------------- 数据库链接字符串: Data Source=*.*.*.*;InitialCatalog=DatabaseName;Persist Security Info=True;UserID=****;Password=****** 使用SqlHelper组件处理数据库查询业务,在MSSQL数据库中进行大数据量查询的时候,会经常出现“超时时间已到。在操作完成之前超时时间已过或服务器未响应。”的错误。 原因分析 --------------------------------------------------------------------------------------------------- 1、当数据库表中存在超大数据记录,则在应用程序Command命令执行时,使用默认的数据库链接超时时间(30秒)配置就容易出现以上超时错误; 2、在事务开始BeginTransaction()与事务结束transaction.Commit()中间用到了没有启动事务的过程,如其他查询等,会提示此错误; 3、在web页面上传大批量文件时,也容易出现超时错误; 解决方案 --------------------------------------------------------------------------------------------------- 1、可以在数据库连接字符串中加入以下参数: Connect Timeout=600;Enlist=true; Pooling=true; Max Pool Size=512; Min Pool Size=0;Connection Lifetime=600 2、如果数据量非常大,以上超时错误仍然存在,则可以在数据库创建链接时自定义延长数据库执行超时时间,并参考以下代码段: using (SqlCommand cmd = new SqlCommand()) { } 3、对于web应用程序超时,可以在web.config中增加以下语句: <system.web> </system.web> httpRuntime:是配置asp.nethttp运行时设置,以确定如何处理对asp.net应用程序的请求; executionTimeout:表示允许执行请求的最大时间限制,单位为秒; maxRequestLength:指示 ASP.NET支持的最大文件上载大小,该限制可用于防止因用户将大量文件传递到该服务器而导致的拒绝服务攻击。指定的大小以 KB 为单位。默认值为4096 KB (4 MB); ~其他配置参考~ useFullyQualifiedRedirectUrl:表示指示客户端重定向是否是完全限定的(采用"http://server/path" 格式,这是某些移动控件所必需的),或者指示是否代之以将相对重定向发送到客户端。如果为True,则所有不是完全限定的重定向都将自动转换为完全限定的格式。false 是默认选项; minFreeThreads:表示指定允许执行新请求的自由线程的最小数目。ASP.NET为要求附加线程来完成其处理的请求而使指定数目的线程保持自由状态。默认值为 8; minLocalRequestFreeThreads:表示ASP.NET保持的允许执行新本地请求的自由线程的最小数目。该线程数目是为从本地主机传入的请求而保留的,以防某些请求在其处理期间发出对本地主机的子请求。这避免了可能的因递归重新进入Web 服务器而导致的死锁; appRequestQueueLimit:表示ASP.NET将为应用程序排队的请求的最大数目。当没有足够的自由线程来处理请求时,将对请求进行排队。当队列超出了该设置中指定的限制时,将通过“503- 服务器太忙”错误信息拒绝传入的请求; enableVersionHeader:表示指定ASP.NET 是否应输出版本标头。Microsoft Visual Studio 2005 使用该属性来确定当前使用的ASP.NET 版本。对于生产环境,该属性不是必需的,可以禁用。 该文章在 2012/3/2 23:10:35 编辑过 |
关键字查询
相关文章
正在查询... |