Я хочу сообщить пользователю, что запись не была удалена, поскольку она имеет дочерние данные, но как я могу быть уверен, что исключение было вызвано из-за нарушения внешнего ключа? Я вижу, что существует класс sqlexception, который используется для всех исключений sql.
Как узнать, возникла ли SQLexception из-за нарушения внешнего ключа?
Ответ 1
Предположим, что вы используете 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 - ваш человек.
UPDATE Вышеприведенный примерный код и его не следует использовать. Пожалуйста, перейдите по ссылке, чтобы объяснить, почему.
Ответ 2
Вы можете написать свой код, ожидающий исключения, в блоке 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;
}
}
}