aspx 执行SQL时超时的解决方案
2014-05-29 01:10
176 查看
这个是网上找到的处理方法:
超时异常分两种情况:一种,是连接超时;一种,是执行超时。
前者,通过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、引入后台线程,由线程操作静态对象,可以很好的解决超时的问题。
当然还有是使用nosql了,只是要更换的东西比较多了。
相关文章推荐
- ASP.NET执行SQL超时的解决方案
- ASP.NET- 执行SQL超时的解决方案
- ASP.NET执行SQL超时的解决方案
- ASP.NET执行SQL超时的解决方案
- 在执行该操作期间发生意外错误:【microsoft sql-dmo(odbc sqlstate:42000)】 解决方案
- SQL Broker SET ENABLE_BROKER 一直在执行,卡在那里解决方案
- sql无效字符 执行sql语句报错解决方案
- 使用Hibernate时如果遇到SQL数据库字段中有使用到SQL关键字时无法执行的解决方案
- 获取aspx页面执行时间完全解决方案
- 同样的SQL语句在查询分析器执行很快,但是网站上执行超时的诡异问题
- 执行存储过程,或者sql语句超时,解决办法
- iBatis应用--控制执行SQL时的超时时间
- 动态执行SQL语句,“SELECT TOP N *”语句中“N”不能为变量的解决方案
- 寻求执行sql时超时解决办法?
- 执行存储过程超时 SQL
- 执行存储过程,或者sql语句超时,解决办法(转)
- C#执行SQL语句报超时已过期
- 大数据量执行SQL或存储过程超时的问题
- C#执行SQL语句报超时已过期
- DB2用work action设置数据库SQL执行超时后终止