开发者

SqlException constraint violation

开发者 https://www.devze.com 2022-12-24 08:02 出处:网络
I\'m working on an asp.ne开发者_Python百科t app. Is there a way, when catching a SqlException, to know which constraint was violated?SqlException has a collection of SqlError objects: Errors. The Sql

I'm working on an asp.ne开发者_Python百科t app. Is there a way, when catching a SqlException, to know which constraint was violated?


SqlException has a collection of SqlError objects: Errors. The SqlError have properties for error Number and you can compare this with the known constraint violation error numbers (eg. 2627).

While is true that SqlException itself exposes a Number property, it is not accurate if multiple errors happen in a single batch and hence is better to inspect the Errors collection.


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
        }
    }
}


You have to add exception handler for the ConstraintException if I understand your question correctly

try
{

}
catch(ConstraintException exc)
{
//exc.Message 
}


Are you letting the exception bubble up? If you don't catch it and turn custom errors off in the web.config i believe it will display it in your browser. If you are catching it i would put a break point in the catch section and inspect the exception there.


The best thing is to catch this catch exception in your C# code behind.

catch(SqlException ex)
{
    if (ex.Message.Contains("UniqueConstraint"))
        throw new UniqueConstraintException();

    throw;
} 

You can create your own exception and throw that from your data layer, otherwise you can directly catch the exception as mentioned above.

using System; 

public class UniqueConstraintException : Exception
{
} 
0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号