近来遇到这样一个错误:Timeout 时间已到。在操做完成以前超时时间已过或服务器未响应。错误截图以下:html
错误缘由分析:
产生错误时我执行的操做须要的执行时间比较长。我测试了一下,那个操做用到的存储过程,须要处理的数据有13多万条,须要执行时间大概是1分40秒。下图是当时执行时的截图。
数据库
而客户端与数据库链接时间以及命令的执行时间都是有限的,当这两个时间其中一个小于操做时间,错误就会产生。
解决方法:
第一步:修改Web.config配置文件。在数据库链接字符串中加上链接时间Connect Timeout,根据实际状况定时间。
服务器
第二步:修改command对象的CommandTimeout属性。 app
这里设置的时间是180秒,即三分钟!可根据须要设置,若是过长,也能够设置为0,当此属性设置为0时表示不限制时间。此属性值应该慎用。
到此为止,问题完美解决。
补充:
SqlCommand.CommandTimeOut:获取或设置在终止执行命令的尝试并生成错误以前的等待时间。
SqlConnection.ConnectionTimeout:获取在尝试创建链接时终止尝试并生成错误以前所等待的时间。oop