Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.51/35: Рейтинг темы: голосов - 35, средняя оценка - 4.51
 Аватар для BlackZombie
4 / 4 / 2
Регистрация: 29.03.2009
Сообщений: 59
.NET 4.x

Как правильно вывести пользователю сообщение об ошибке при срабатывании исключения в БД

09.01.2012, 12:41. Показов 7369. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется БД в SQL Server 2008 R2 и клиентское приложение на WPF, которое работает с этой БД при помощи Entity Framework. К примеру в БД имеется таблица "студенты", где номер зачётки каждого студента уникален, т.е. сделан constraint. Если пользователь через клиентское приложение попытается добавить в таблицу студента, у которого будет уже существующий номер зачётки, то вылетит исключение. Вопрос в следующем: отлавливая такого рода исключения как-то можно достать параметры, по которым можно было бы определить, что это за тип ошибки, какая операция её вызвала и почему? Нужно всё это для того, чтобы пользователю вывести сообщение об ошибке в человеческом формате, а не просто MessageBox.Show(ex.Message), который к примеру выводит такой ужас для пользователя:

Операция завершилась с ошибкой. Не удалось изменить связь, поскольку один или несколько свойств внешнего ключа не допускают значения NULL. При изменении связи соответствующему свойству внешнего ключа присваивается значение NULL. Если внешний ключ не поддерживает значений NULL, должна быть определена новая связь, свойству внешнего ключа должно быть присвоено другое значение, отличное от NULL, либо необходимо удалить несвязанный объект.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.01.2012, 12:41
Ответы с готовыми решениями:

Выход из цикла при срабатывании исключения
int main() { cout << "калькулятор" << endl; cout << "введите число" << endl; cin >> a; while (!q) { ...

Как получить сообщение об ошибке, если я обрабатываю ВСЕ исключения
Здравствуйте, как мне получить сообщение об ошибке, если я обрабатываю все исключения, а не конкретное? try { //блок } catch...

Как при срабатывании SIGINT правильно передать значение переменной i в функцию closing
Имеется код: #include <signal.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> void closing(int number) {...

9
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
09.01.2012, 13:06
Можно предположить, что в клиентском приложении не реализованы (криво реализованы) обработки исключений
0
 Аватар для BlackZombie
4 / 4 / 2
Регистрация: 29.03.2009
Сообщений: 59
09.01.2012, 13:27  [ТС]
Цитата Сообщение от pincet Посмотреть сообщение
Можно предположить, что в клиентском приложении не реализованы (криво реализованы) обработки исключений
Так вопрос в том как это реализовать в клиентском приложении? Или я не в том разделе создал тему?)
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
09.01.2012, 13:55
клиента кто разрабатывает?
если ты - курим обработку исключительных ситуаций
0
56 / 56 / 10
Регистрация: 27.12.2011
Сообщений: 141
09.01.2012, 16:07
Обработка исключений не сложно делается. Прочитай про операторы try {} catch {}
Вот каким образом поймать исключение:
C#
1
2
3
4
5
6
7
8
9
try
{
 //тут выполняешь действия с базой данных
}
catch(Exeption ex)//если в try возникнет исключение, обрабатываем его ниже в catch, к примеру выводим сообщение с текстом ошибки
{
  MessageBox.Show(ex.ToString());
}
//Самое удобное что если мы обрабатываем исключение, программа не вылетает при сбое а продолжает работать
0
 Аватар для BlackZombie
4 / 4 / 2
Регистрация: 29.03.2009
Сообщений: 59
09.01.2012, 17:05  [ТС]
Цитата Сообщение от pincet Посмотреть сообщение
клиента кто разрабатывает?
если ты - курим обработку исключительных ситуаций
Я бы и рад покурить, да только гугл ничего особо полезного не выдаёт. Может подскажете направление?

Цитата Сообщение от Караман Посмотреть сообщение
Обработка исключений не сложно делается. Прочитай про операторы try {} catch {}
Вот каким образом поймать исключение:
C#
1
2
3
4
5
6
7
8
9
try
{
 //тут выполняешь действия с базой данных
}
catch(Exeption ex)//если в try возникнет исключение, обрабатываем его ниже в catch, к примеру выводим сообщение с текстом ошибки
{
  MessageBox.Show(ex.ToString());
}
//Самое удобное что если мы обрабатываем исключение, программа не вылетает при сбое а продолжает работать
Народ, я не настолько тупой, я знаю как отловить исключение, проблема в том, что в EF все действия выполняются на клиентской стороне и потом посредством команды context.SaveChanges()
применяются все операции непосредственно к БД. Вот к примеру:

C#
1
2
3
4
5
6
7
8
try
{
        context.SaveChanges();
}
catch (Exception ex)
{
        MessageBox.Show(ex.InnerException.Message);
}
Если в этом случае возникнет ошибка, то как мне пользователю в человеческом виде вывести сообщение о том, что он сделал не так? Как можно достать инфу из объекта ex об операции вызвавшей исключение?

Если бы я для работы с базой данных использовал обычные sql запросы, то вопросов бы не было. Выполнили запрос, в случае исключения вывели сообщение об ошибке, и так на каждый запрос.
0
56 / 56 / 10
Регистрация: 27.12.2011
Сообщений: 141
09.01.2012, 18:08
Как бы у каждой ошибки есть код. Забей в гугле про коды ошибок и что каждая означает, сделай функцию которая по коду ошибки будет возвращать удобоваримое сообщение которое ему подскажет что он сделал не так. Может есть и другие варианты.
0
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
09.01.2012, 19:45
В твоем случае ex - экземляр класса Exception. Курим в MSDN про этот класс, получаем удовольствие
0
 Аватар для BlackZombie
4 / 4 / 2
Регистрация: 29.03.2009
Сообщений: 59
12.01.2012, 17:07  [ТС]
В общем нифига у меня не получается из эксепшена достать полезной инфы об ошибке. Кроме того у меня на одну и ту же операцию генерируются через раз аж 2 типа исключения, то EF выбрасывает исключение, то sql. По этому поводу вычитал здесь - http://stackoverflow.com/quest... y-instance , но так и не понял с какого перепуга выбрасывает то одно исключение, то совсем другое.

Кстати, если из SqlException ещё можно хоть какую-то полезную инфу об ошибке получить, то в случае InvalidOperationException полезной инфы ноль, к сожалению как раз InvalidOperationException срабатывает чаще.
0
56 / 56 / 10
Регистрация: 27.12.2011
Сообщений: 141
12.01.2012, 18:27
If EF finds that any tracked order related to the deleted customer is also not marked as deleted it will fire an exception (probably InvalidOperationException). - проверяй объекты помеченные на удаление на связи. Это кстати очень вероятная ошибка. А вообще ты мог бы сам логически подумать, зная структуру базы данных, и вывести пользователю наиболее вероятную ошибку при том или ином действии.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.01.2012, 18:27
Помогаю со студенческими работами здесь

Вывести сообщение об ошибке при выполнении кода
Здравствуйте, не могу допетрить, как прикрутить сообщение с ошибкой (отсутствует связь с удаленным компьютером) Делаю проверку типа...

При вводе неправильного значения для N вывести сообщение об ошибке
Дано натуральное число N.Найти p=1*2*...*N.При вводе неправильного значения для N вывести сообщение об ошибке.

Как вывести сообщение об ошибке
Как для этой case "er": throw new Exception( "Ошибка в строке ввода"); написать обработчик ошибок. switch (opCommand) ...

Где возникают исключения при ошибке отправления сообщения через сокет?
Я написал следующий код: public static void SendCallback(IAsyncResult AR) { Client client = (Client)AR.AsyncState; ...

Как вывести сообщение в echo об ошибке регистрации
Подскажите, пожалуйста, как в данном скрипте вывести сообщение в echo в переменную $error_message = '' об ошибке ? <?php ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru