[ADO.NET]MSSQL执行处理时出现Time…

ADO.NET在执行耗时的操作时,容易出现以下错误:
---------------------------
Timeout expired.   The timeout period elapsed prior to completion of the operation or the server is not responding.
---------------------------
这里需要注意的是
SqlCommand.CommandTimeout 和 SqlConnection.ConnectionTimeout是不同的概念,且通常需要我们自定义设置。

区别如下:
SqlCommand.CommandTimeout
获取或设置在终止执行命令的尝试并生成错误之前的等待时间。
等待命令执行的时间(以秒为单位)。默认为 30 秒。


SqlConnection.ConnectionTimeout
获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。
等待连接打开的时间(以秒为单位)。默认值为 15 秒。

SqlCommand.CommandTimeout 的默认值是30,通常能满足大多数程序的需求。但一旦碰到大数据量操作或耗时的操作时,就容易引发上面的错误。

解决方法较为简单:

            SqlCommand cmd = new SqlCommand();
            cmd.CommandTimeout = 60;

当然,出现超时的情况还要判断是否存在脚本性能问题或数据库性能问题,则需要深入分析并优化。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

名栩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值