首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >违反SqlException约束

违反SqlException约束
EN

Stack Overflow用户
提问于 2010-03-25 23:52:27
回答 5查看 13.8K关注 0票数 4

我正在开发一个asp.net应用程序。在捕获SqlException时,有没有办法知道违反了哪个约束?

EN

回答 5

Stack Overflow用户

发布于 2010-03-26 01:16:45

SqlException有一个SqlError对象的集合:ErrorsSqlError具有error Number的属性,您可以将其与已知的违反约束的错误编号进行比较(例如,2627)。

虽然SqlException本身公开了一个Number属性,但如果在单个批处理中发生多个错误,这是不准确的,因此最好检查errors集合。

票数 8
EN

Stack Overflow用户

发布于 2013-04-09 18:15:49

代码语言:javascript
复制
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
        }
    }
}
票数 4
EN

Stack Overflow用户

发布于 2010-03-25 23:55:52

如果我正确理解了您的问题,您必须为ConstraintException添加异常处理程序

代码语言:javascript
复制
try
{

}
catch(ConstraintException exc)
{
//exc.Message 
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2517064

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档