phimiler 2021-07-30 17:54 采纳率: 33.3%
浏览 19

sqlServer中插入记录失败,如何判断是网络原因还是违反了约束

在C#的try...catch结构中,我在try块中执行了插入语句操作,在catch块中捕获SqlException异常,发现如下现象:

  1. 网络断线和服务器关闭,均会引发SqlException异常
  2. 如果其他正常,但违反了表的约束,也会引发SqlException异常
    那么我的问题是,如何区分这两种引发程序异常的原因(以便我采取不同的对策)?
    我现在的做法是依旧捕获SqlException异常,但是用异常过滤器限制只捕获异常消息中含有"重复键"关键字的SqlException异常,这肯定不是好办法.
  • 写回答

2条回答 默认 最新

  • 刘瑾言 2021-07-30 18:03
    关注

    判断异常的类型阿.
    像主键重复,异常是DuplicateKeyException

    评论

报告相同问题?

问题事件

  • 创建了问题 7月30日

悬赏问题

  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作