加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

MSSQL数据库查询“超时时间已到……”的解决方案

(2010-02-21 17:15:33)
标签:

ms

sql

超时时间已到

在操作完成之前

超时时间已过

服务器未响应

it

分类: SQL笔记
问题描述
---------------------------------------------------------------------------------------------------
数据库链接字符串:
Data Source=*.*.*.*;Initial Catalog=DatabaseName;Persist Security Info=True;User ID=****;Password=******
使用SqlHelper组件处理数据库查询业务,在MS SQL数据库中进行大数据量查询的时候,会经常出现“超时时间已到。在操作完成之前超时时间已过或服务器未响应。”的错误。

原因分析
---------------------------------------------------------------------------------------------------
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())
{
    using (SqlConnection connection = new SqlConnection(dbConnStr))
    {
        connection.Open();

        cmd.Connection = connection;
        cmd.CommandTimeout = cmd.Connection.ConnectionTimeout;

        cmd.CommandText = sqlStr; //数据库执行查询语句,内容略
        object temp1 = cmd.ExecuteScalar(); //同样适用于其他数据库操作

        connection.Close();
    }
}

3、对于web应用程序超时,可以在web.config中增加以下语句:
<system.web>
        <httpRuntime maxRequestLength="102400" executionTimeout="1800" />
</system.web>
httpRuntime:是配置asp.net http运行时设置,以确定如何处理对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 版本。对于生产环境,该属性不是必需的,可以禁用;

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有