Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
1 / 1 / 3
Регистрация: 07.10.2011
Сообщений: 56
.NET 4.x

Вывод messagebox при ошибке записи в базу

06.11.2012, 18:10. Показов 2157. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день) Есть главная форма и есть форма через которую пользователь забивает значения, которые затем перпедаются в запрос и записываются в базу. Хочу отлавливать одну колонку на уникальность значений и не давать пользователю занести в базу. Колонка в базе отмечена на уникальность. Вся работа с базой прописана в длл. Теперь есть такой запрос
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
public int InsertData(newData myData)
        {
 
 
            SqlCommand com = new SqlCommand("Insert Into Torg" + "(cid, и т.д.) Values (@cid, и т.д.)", this.sqlCn);
           SqlParameter param = new SqlParameter();
           param.ParameterName = "@cid"; param.Value = myData.cid; param.SqlDbType = SqlDbType.VarChar; com.Parameters.Add(param);
           //добавляем все наши параметры
           param = new SqlParameter();
           параметры .............
 
           
           try
           {
               
               com.ExecuteNonQuery();
           }
           catch (SqlException ex)
           {
               if (ex.Number.Equals(2627) )
               MessageBox.Show("Такой номер торгов уже занесен в базу. Проверьте номер.", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
               return 1;
           }
           return 0;
 
 
        }
Теперь в самой программе выполняю запрос при нажатии кнопочки ОК
C#
1
2
3
4
5
6
7
8
9
 workData mynewData = new workData();
            mynewData.OpenConnection();
            mynewData.InsertData(mynewData.createData(dcid,  и.д.));
            if (mynewData.InsertData(mynewData.createData(dcid, и.д.)) == 0)
            {
                Close();
                mynewData.CloseConnection();
            }
            else mynewData.CloseConnection();
Проблема в том, что при нажатии ОК выскакивает мое окошко с ошибкой, я нажимаю ок в окне с ошибкой, и оно повторно появляется. Как будто нажали повторно запись в базу. Если же убрать вот эту проверку if (mynewData.InsertData(mynewData.createDa ta(dcid, и.д.)) == 0) то срабатывает закрытие формы. А мне требуется отловить эту ошибку, при вводе неуникального значения чтобы выскакивало окошко с описанием ошибки, нажав Ок в окне с ошибкой форма где вводятся даные тоже не закрывалась. Подскажите пожалуйста как можно этого добиться.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.11.2012, 18:10
Ответы с готовыми решениями:

Сохранение в базу при ошибке
мой скрипт при начале работы сохраняет в базу 1 работать а когда заканчивает то сохраняет 0, но как сделать чтобы если была какая то...

Исключение при ошибке записи в бд sql
Доброго времени суток! В общем, в моей программе я ввожу в текст боксы некоторую информацию и записываю в бд sql. При попытке добавлении...

Ошибке при заходе на базу Access: Driver's SQLSetConnectAttr failed /test.asp, line 9
Я пытaюсь зaйти в aксесoвскую бaзу дaнных <% set C=server.CreateObject('adodb.connection') c.Open 'dsn=seebox' set...

1
9 / 9 / 5
Регистрация: 08.10.2012
Сообщений: 48
06.11.2012, 18:27
C#
1
2
mynewData.InsertData(mynewData.createData(dcid,  и.д.));
if (mynewData.InsertData(mynewData.createData(dcid, и.д.)) == 0)
Ты два раза вызываешь функцию, просто убери верхнюю строку и попробуй

Добавлено через 3 минуты
И получается что при удачном занесении данных у тебя закрывается форма, а при ошибке закрывается конект. Как то непонятно что тебе нужно
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.11.2012, 18:27
Помогаю со студенческими работами здесь

MessageBox при записи массива чисел в файл
int mas = {48, 49, 50, 51, 52, 53, 54 ,55, 56, 57}; for (int i = 0; i < 10; ++i){ DWORD dwBytesWrite; if(!WriteFile( ...

Вывод лишних значений при ошибке
<html> <body> <? function my() {?> <form action="new2.php" method=get></br> Login <input type=text name=log value=""></br>...

Вывод MessageBox при нажатии на определенные Checkbox
На работе дали такое задание. Существует анкета в Word, с 10 балльной оценкой. Необходимо ее доработать таким образом, чтобы при ответе...

MessageBox вывод сообщения при клике на кнопку
MessageBox ( NULL, "Hello World!", "Test", MB_OK ); Error 1 error C2065: 'NULL' : undeclared identifier c:\documents and...

Вывод в TextBox: вызов MessageBox при исключении
Доброго времени суток, форумчане, возникла проблема с CLR проектом. У меня есть С++ код, который впринципе делает всё что надо, но в...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru