本文较为详细的讲解了C#百万数据查询出现超时问题的解决方法,分享给大家供大家参考之用。具体方法如下:
很多时候我们用C#从百万数据中筛选一些信息时,经常会出现程序连接超时的错误,常见的错误有很多,例如:
Timeout expired. The timeout period elapsed prior to completion of the operation or the server
等等
本文就常见的几种解决方案进行说明,感兴趣的可以对此加以改进与完善。
①.当然第一步要查看是否Connection没关闭问题,一般新手都会犯这个错误,需要认真查看一下哦,这个就不详细说了。
②.如果将sql语句复制到查询分析器中执行,如果执行时间本来就超过30秒,那么一般采用如下的解决方案:
首先分析引起Timeout的原因,一般是Connection没关闭或者SqlConnection.ConnectionTimeout超时,另外一种就是SqlCommand.CommandTimeout引起的, SqlCommand的此方法为获取或设置在终止执行命令的尝试并生成错误之前的等待时间,
他的
默认为 30 秒,你可以设置为0 ,它表示无限制,但是最好不要去设置0 ,否则会无限的等待下去的,只需要针对查询分析器的时间,去设置这个时间就可以了
③.执行时间不是很长,但是还是操作超时,那么 也有很多原因,一般经常出现的有两种,asp.Net应用程序的请求超时,或者是连接池的连接生存期过去,,因为连接池默认值是60秒,那么针对这两种解决方案为:
解决应用程序请求超时:
在web.config中加上以下语句:
<system.web> <httpRuntime maxRequestLength="102400" executionTimeout="720" /> </system.web>
executionTimeout:是允许执行请求的最大时间限制,单位为秒
maxRequestLength:指示 ASP.Net 支持的最大文件上载大小。该限制可以防止。大家都懂的。
解决程序池生存周期问题:
在数据库连接字符串中修改:
database=AA; uid=sa; pwd=sa; Pooling=true; MAX Pool Size=1024; Min Pool Size=1; Connection Lifetime=60
至于含义基本上从英文的意思上大家就明白了,呵呵。当然Min Pool Size=1这个设置还有很多讲究。
希望本文所述对大家的C#程序设计有所帮助。
除声明外,跑步客文章均为原创,转载请以链接形式标明本文地址
C#百万数据查询出现超时问题的解决方法
本文地址: http://www.paobuke.com/develop/c-develop/pbk23552.html
相关内容
C#逆变与协变详解
C#实现文件上传及文件下载功能实例代码
C#基于正则表达式抓取a标签链接和innerhtml的方法
C# winform点击生成二维码实例代码
C# 实现与现有.NET事件桥接简单实例
C#限速下载网络文件的方法实例
利用C#实现网络爬虫
C#使用Matrix执行缩放的方法