Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
2014-04-16 16:07
204 查看
近来遇到这样一个错误:Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。错误截图如下:
错误原因分析:
产生错误时我执行的操作需要的执行时间比较长。我测试了一下,那个操作用到的存储过程,需要处理的数据有13多万条,需要执行时间大概是1分40秒。下图是当时执行时的截图。
而客户端与数据库连接时间以及命令的执行时间都是有限的,当这两个时间其中一个小于操作时间,错误就会产生。
解决方法:
第一步:修改Web.config配置文件。在数据库连接字符串中加上连接时间Connect Timeout,根据实际情况定时间。
[html] view plaincopy
<!--连接数据库-->
<connectionStrings>
<add name="strConnDB" connectionString=" Data Source=192.168.*.*;Initial Catalog=DatabaseName;Persist Security Info=True;User id=sa;Password=password;pooling=true;max pool size=800;min pool size=300;<span style="color:#FF0000;">Connect Timeout=500</span>;"/>
</connectionStrings>
第二步:修改command对象的CommandTimeout属性。
[csharp] view plaincopy
SqlCommand cmd = new SqlCommand();
cmd.CommandTimeout = 180;
这里设置的时间是180秒,即三分钟!可根据需要设置,如果过长,也可以设置为0,当此属性设置为0时表示不限制时间。此属性值应该慎用。
到此为止,问题完美解决。
补充:
SqlCommand.CommandTimeOut:获取或设置在终止执行命令的尝试并生成错误之前的等待时间。
SqlConnection.ConnectionTimeout:获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。
错误原因分析:
产生错误时我执行的操作需要的执行时间比较长。我测试了一下,那个操作用到的存储过程,需要处理的数据有13多万条,需要执行时间大概是1分40秒。下图是当时执行时的截图。
而客户端与数据库连接时间以及命令的执行时间都是有限的,当这两个时间其中一个小于操作时间,错误就会产生。
解决方法:
第一步:修改Web.config配置文件。在数据库连接字符串中加上连接时间Connect Timeout,根据实际情况定时间。
[html] view plaincopy
<!--连接数据库-->
<connectionStrings>
<add name="strConnDB" connectionString=" Data Source=192.168.*.*;Initial Catalog=DatabaseName;Persist Security Info=True;User id=sa;Password=password;pooling=true;max pool size=800;min pool size=300;<span style="color:#FF0000;">Connect Timeout=500</span>;"/>
</connectionStrings>
第二步:修改command对象的CommandTimeout属性。
[csharp] view plaincopy
SqlCommand cmd = new SqlCommand();
cmd.CommandTimeout = 180;
这里设置的时间是180秒,即三分钟!可根据需要设置,如果过长,也可以设置为0,当此属性设置为0时表示不限制时间。此属性值应该慎用。
到此为止,问题完美解决。
补充:
SqlCommand.CommandTimeOut:获取或设置在终止执行命令的尝试并生成错误之前的等待时间。
SqlConnection.ConnectionTimeout:获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。
相关文章推荐
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- 解决SQLServer中变更海量数据表结构时产生【无法修改表. Timeout 时间已到. 在操作完成之前超时时间已过或服务器未响应. 】
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。 (.Net SqlClient Data Provider)
- sqlserver Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- 问题:“Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。”的解决方法
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。
- timeout Timeout时间已到.在操作完成之前超时时间已过或服务器未响应
- 超时时间已到。在操作完成之前超时时间已过或服务器未响应"的解决方法
- 使用数据集时错误:超时时间已到。在操作完成之前超时时间已过或服务器未响应。
- 解决ASP.NET Web Applicatio超时时间已到.在操作完成之前超时时间已过或服务器未响应
- c#执行插入sql 时,报错:异常信息:超时时间已到。在操作完成之前超时时间已过或服务器未响应
- 超时时间已到。在操作完成之前超时时间已过或服务器未响应
- 解决ASP.NET Web Applicatio超时时间已到.在操作完成之前超时时间已过或服务器未响应