Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
17 / 17 / 17
Регистрация: 14.01.2015
Сообщений: 105

При возникновении исключения на Unique срабатывает счетчик id

30.04.2015, 22:11. Показов 1368. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть таблица, id - счетчик. В таблице есть поле "Номер", которое задано Unique. Если пытаюсь добавить строку с повторяющимся номером, то вылетает ошибка, но счетчик все равно срабатывает +1. Почему срабатывает счетчик и как это исправить? Обработка исключительных ситуаций есть, но не помогает.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.04.2015, 22:11
Ответы с готовыми решениями:

Закрытие программы при возникновении исключения
Добрый вечер! Возник такой вопрос... Есть WinForms приложение работающее с файлом БД Access. При запуске программа в блоке try...

Продолжение работы цикла при возникновении исключения
У меня есть цикл который обрабатывает тексты. for (int i = 0; i < n; i++) { ...... } ...

При возникновении исключения приложение тупо вырубается
Непонятная для меня проблема. Генерирую в коде искуственно исключение. По идее должно ведь стандартное окошко фреймворка появиться с...

4
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18242 / 14156 / 5366
Регистрация: 17.03.2014
Сообщений: 28,846
Записей в блоге: 1
01.05.2015, 07:40
Лучший ответ Сообщение было отмечено Дурак как решение

Решение

Дурак, ты не сказал какая у тебя БД. Если MS SQL, то по моему это сделано из соображений простоты. То есть при INSERT сразу генерируется новый ID. Это должно делаться с учетом того что паралельно могут идти другие INSERT-ы. Соответственно СУБД ставит некую блокировку, получает новое значение ID, сохраняет его как последнее использованное и отпускает блокировку. Для колонок типа int это может делаться одним вызовом к методу вроде Interlocked.Increment. Получив ID СУБД двигается дальше - выполняет проверки на обязательные поля, ограничения ключей и т.п. В случае ошибки на этом этапе СУБД возвращает ошибку без дополнительных действий. Ты по сути ожидаешь что здесь надо делать откат на старое значение. Но паралельно могут выполняться десятки или сотни других INSERT-ов. Лишняя операция обновления ID замедлит их. То есть проще и эффективнее делать инкремент один раз. В итоге - игнорируй это поведение. Если тебек нужная непрерывная нумерация, то это нужно делать как-то по другому.
1
17 / 17 / 17
Регистрация: 14.01.2015
Сообщений: 105
01.05.2015, 10:40  [ТС]
Да, простите, база MS SQL. А если счетчик достигнет максимального значения, при добавлении новых строк программа будет выдавать ошибку или счетчик будет брать свободные значения?
Цитата Сообщение от OwenGlendower Посмотреть сообщение
Если тебек нужная непрерывная нумерация, то это нужно делать как-то по другому.
Может, тогда сделать отдельных запрос на проверку уникального значения?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18242 / 14156 / 5366
Регистрация: 17.03.2014
Сообщений: 28,846
Записей в блоге: 1
01.05.2015, 11:23
Цитата Сообщение от Дурак Посмотреть сообщение
А если счетчик достигнет максимального значения, при добавлении новых строк программа будет выдавать ошибку или счетчик будет брать свободные значения?
Будет сгенерирована ошибка. Если данных очень много, то следует использовать bigint вместо int или переходить на uniqueidentifier.

Цитата Сообщение от Дурак Посмотреть сообщение
Может, тогда сделать отдельных запрос на проверку уникального значения?
Сделай.
1
17 / 17 / 17
Регистрация: 14.01.2015
Сообщений: 105
01.05.2015, 14:20  [ТС]
спасибо большое!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.05.2015, 14:20
Помогаю со студенческими работами здесь

Запись в файл с откатом при возникновении ошибки/исключения
Добрый день! Такой вопрос: допустим идет построчная запись в файл 1000-чи строчек. Допустим на 501-ой вылетает исключение, стоит трай-кетч....

Уничтожить объект при возникновении в конструкторе обрабатываемого исключения
Наверняка ведь случается, что в конструкторе возникает исключение (неправильные данные и т.д.), а как в таком случае прописать в...

Windows 10 и студия 14 (обе enterprise) завершает отладку при возникновении исключения
Раньше была windows 8.1 enterprise, но 90 дневная лицензия кончилась, решил попробовать windows 10 enterprise. Поставил с веб-установщика...

Поле Unique. Как правильно написать обработку исключения в RowValidating
Когда заношу значение в ячейку DataGridView которая привязана к unique полю в базе возникает исключение при валидации строки грида. Как...

На срабатывает счетчик страниц
<div class="page"> <?php query_posts('cat=6&showposts=5'); ?> <h2 class="page_title"><?php the_title() ?></h2> <hr> ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru