c# – 捕获唯一键冲突的通用方法

我使用System.Data.Common.DbCommand将新行插入数据库.关键是,这一行已经存在.
try
{
    [...]
    DbCommand insertCommand = [...]
    insertCommand.ExecuteScalar();
    [...]
}
catch (System.Exception exception)
{
   [...]
   throw;
}

如果我将显式捕获System.Data.sqlClient.sqlException,我可以像下面一样评估ErrorNumber.

try
{
  //insertion code
}
catch(sqlException ex)
{
  if(ex.Number == 2627)
  {
     //Violation of primary key. Handle Exception
  }
}

sqlException上下文中的ErrorNumber 2627意味着违反唯一键.见https://msdn.microsoft.com/en-us/library/ms151757%28v=sql.110%29.aspx

到现在为止还挺好.因为我正在使用DbCommand,因此使用不同类型的关系数据库管理系统,我正在寻找一种更通用的方式来捕获这种违反唯一键约束的行为.

感谢帮助.

解决方法

我担心没有内置的通用解决方案.作为一种解决方法,您可以为Execute …创建一个包装器:
public static int ExecuteWithNiceExceptions(this IDbCommand cmd)
{
    try
    {
        return cmd.ExecuteNonQuery();
    }
    catch(sqlException ex)
    {
        if (ex.Number == 2627)
        {
            throw new PrimarykeyviolationException(cmd,ex);
        }
        else
        {
            throw;
        }
    }
    catch (OleDbException ex)
    {
        ... 
    }
    ...
}

这样,您可以将不同的,特定于实现的异常“转换”为通用的,有意义的异常.

相关文章

原文地址:http://msdn.microsoft.com/en-us/magazine/cc163...
前言 随着近些年微服务的流行,有越来越多的开发者和团队所采...
最近因为比较忙,好久没有写博客了,这篇主要给大家分享一下...
在多核CPU在今天和不久的将来,计算机将拥有更多的内核,Mic...
c语言输入成绩怎么判断等级
字符型数据在内存中的存储形式是什么