我正在开发一个asp.net应用程序。在捕获SqlException时,有没有办法知道违反了哪个约束?
发布于 2010-03-26 01:16:45
SqlException有一个SqlError对象的集合:Errors。SqlError具有error Number的属性,您可以将其与已知的违反约束的错误编号进行比较(例如,2627)。
虽然SqlException本身公开了一个Number属性,但如果在单个批处理中发生多个错误,这是不准确的,因此最好检查errors集合。
发布于 2013-04-09 18:15:49
catch (SqlException ex)
{
if (ex.Errors.Count > 0) // Assume the interesting stuff is in the first error
{
switch (ex.Errors[0].Number)
{
case 547: // Foreign Key violation
throw new InvalidOperationException("Your FK user-friendly description", ex);
break;
// other cases
}
}
}发布于 2010-03-25 23:55:52
如果我正确理解了您的问题,您必须为ConstraintException添加异常处理程序
try
{
}
catch(ConstraintException exc)
{
//exc.Message
}https://stackoverflow.com/questions/2517064
复制相似问题