ASP.NET- 执行SQL超时的解决方案
2015-08-27 09:06
411 查看
在我们编写程序的时候,有时候要进行复杂的查询时,就会出现执行sql时间过长,引起页面执行不了并提示执行脚本超时,这就是我们遇到超时异常。
超时异常分两种情况:一种,是连接超时;一种,是执行超时。
前者,通过SqlConnection.ConnectionTimeOut进行设置。
后者,通过SqlCommand.CommandTimeOut进行设置。
SqlConnection.ConnectionTimeout
获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。
等待连接打开的时间(以秒为单位)。默认值为 15 秒。
SqlCommand.CommandTimeout
获取或设置在终止执行命令的尝试并生成错误之前的等待时间。
等待命令执行的时间(以秒为单位)。默认为 30 秒。
原文网址:/article/4805848.html
超时异常分两种情况:一种,是连接超时;一种,是执行超时。
前者,通过SqlConnection.ConnectionTimeOut进行设置。
后者,通过SqlCommand.CommandTimeOut进行设置。
SqlConnection.ConnectionTimeout
获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。
等待连接打开的时间(以秒为单位)。默认值为 15 秒。
SqlCommand.CommandTimeout
获取或设置在终止执行命令的尝试并生成错误之前的等待时间。
等待命令执行的时间(以秒为单位)。默认为 30 秒。
这个是网上找到的方法: conn.open(); SqlCommand sqlcmd=new SqlCommand(); sqlcmd.CommandTimeout=180; //sqlcmd的超时为3分钟 可根据需要设置,如果过长,也可以设置为0,当此属性设置为0时表示不限制时间。此属性值应该慎用。还需要在Web.config配置文件中设置http请求运行时限间 <system.web> <httpRuntime maxRequestLength="102400" executionTimeout="720" /> </system.web> 这里设置的为720秒,前面的属性maxRequestLength一般用于用户上传文件限制大小!默认一般为4096KB(4 MB)。 |
我在项目中用到的另一种方法: 由于项目需要一次导入至少20万条记录并进行分类筛选、计算、入库操作。 服务器环境不是很好,挂载了太多的网站,所以整个转换过程可能会超过半个小时,此时除服务器可能超时外,浏览器和服务器端的Session都有可能超时,另外用户并不一定需要等待任务完成。当然如果能查看任务进度更好。 解决办法: 1、引入静态对象记录当前的操作状态,使用Ajax实时显示任务完成进度,由于使用了静态对象,即使使用者暂时离开页面再次进入时进度还是在; 2、引入后台线程,由线程操作静态对象,可以很好的解决超时的问题。 |
相关文章推荐
- ASP.NET MVC 中的 T4
- Server2008 II7中配置ASP+Access运行环境
- Spring.Net+NHibernate+asp.net mvc + easyui
- ASP.NET数据绑定方法集合
- 在两个ASP.NET页面之间传递变量【转】
- ASP.NET MVC下的异步Action的定义和执行原理
- asp.net winform 实现复制,粘贴,剪切功能
- ASP如何获取真实IP地址
- asp.net 程序附加到进程ie 时 提示 当前不会命中断点,还没有为该文档加载任何符号
- asp.net XML增删查改操作方法
- Aspose.Words使用教程之从零创建OOXML图表
- BLToolkit AsyncAspect (异步调用)
- ASP.NET MVC 如何在一个同步方法(非async)方法中等待async方法
- asp.net的Form认证登陆
- 一个23岁大学生的Raspberry Pi开源项目
- ASP杂记
- Talking Small: Using Eclipse Paho's MQTT on BeagleBone Black and Raspberry Pi
- asp.net调用存储过程
- Razor:从aspx到cshtml常见错误及正确书写方法
- ASP.NET Web API实践系列11,如何设计出优秀的API