Как я могу узнать, было ли выдано исключение SQL из-за нарушения внешнего ключа? - PullRequest
20 голосов
/ 08 марта 2010

Я хочу сообщить пользователю, что запись не была удалена, поскольку в ней есть дочерние данные, но как я могу быть уверен, что исключение было выдано из-за нарушения внешнего ключа? Я вижу, что есть класс sqlexception, который используется для всех исключений sql.

Ответы [ 2 ]

44 голосов
/ 08 марта 2010

Предположим, вы используете SQL Server.

Использование Googles - http://blogs.msdn.com/tomholl/archive/2007/08/01/mapping-sql-server-errors-to-net-exceptions-the-fun-way.aspx

try
{
    # SQL Stuff
}
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("Some helpful description", ex);
                break;
            case 2601: // Primary key violation
                throw new DuplicateRecordException("Some other helpful description", ex);
                break;
            default:
                throw new DataAccessException(ex);
        }
    }

}

Дело 547 - ваш мужчина.

ОБНОВЛЕНИЕ Приведенный выше пример кода и не должен использоваться. Пожалуйста, перейдите по ссылке, чтобы объяснить, почему.

0 голосов
/ 30 апреля 2016

Вы можете написать свой ожидаемый код исключения в блоке Try, если будет сгенерировано какое-либо исключение, оно будет перехвачено далее, теперь вы можете получить номер ошибки. Теперь мы можем проверить, является ли нарушение внешнего ключа или нет

try
 {

//your deletetion code

 }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
                    lblError.Text = "Cannot Delete this Record this is associated with other record...!";

                    break;
                default:
                  throw;

            }
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...