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

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

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

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

网络问题会提示500或者其他的数据库异常会抛出sql开头的提示。