我使用 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 并因此使用不同类型的关系数据库管理系统,所以我正在寻找一种更通用的方式来捕获这种违反唯一键约束的行为。
感谢帮助。