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