170 похожих чатов

Для OptimisticLockException - можно поставить какой-нить ретрай на 3 попытки. А

для какого-нить DataIntegrityViolationException - что делать? Очень общая ошибка и не всегда нужно ставить ретрай.

12 ответов

5 просмотров

Так по 1 ничего не сделаешь же, ошибка либо в данных, либо в коде. Если запрос с ui, можно валидировать в дто

Владимир-Наваев Автор вопроса
Владислав Хакин
Так по 1 ничего не сделаешь же, ошибка либо в данн...

Ну вот я привел пример с нарушением констрейнта уникальности. Это не ошибка, это race condition

Владимир Наваев
Ну вот я привел пример с нарушением констрейнта ун...

Пока не понимаю, как может быть race condition в таком случае

Владимир-Наваев Автор вопроса
Владислав Хакин
Пока не понимаю, как может быть race condition в т...

Вы когда добавляете пользователя с условием уникальности email или username - вы лочите всю таблицу?

Владимир-Наваев Автор вопроса
Владислав Хакин
Нет. В транзакции изменение

А какого уровня транзакцию юзаете - serializable? Раз таких ошибок у вас нет?

Владимир Наваев
А какого уровня транзакцию юзаете - serializable? ...

А какая ошибка, это же две разные строчки, никак не связанные между собой, откуда нарушение ограничения?

Владимир-Наваев Автор вопроса
Владислав Хакин
А какая ошибка, это же две разные строчки, никак н...

Ну вот у нас констрейнт в бд на уникальность username. Первый пользователь добаляет constraint@mail.com и второй тоже добавляет constraint@mail.com. Бам DataIntegrityViolationException

Владимир Наваев
Ну вот у нас констрейнт в бд на уникальность usern...

Понял, ну в любом случае, ничего не сделать, данные же не поменяем самостоятельно, отдать ошибку на ui. Как при проблеме оптимистичной блокировки, извините, занято имя, не успели

Владимир-Наваев Автор вопроса
Владислав Хакин
Понял, ну в любом случае, ничего не сделать, данны...

Да, но вот след. проблема это как понять, что именно DataIntegrityViolationException означает. Ибо это не всегда конфликт уникальности. Поэтому интересно как правильно обрабатывать DataIntegrityViolationException

вторая ошибка общая

Владимир-Наваев Автор вопроса
Dima
вторая ошибка общая

Да и как ее обрабатывать? Как опознать, что это именно например нарушение уникальности ключа, а не что либо еще?

Похожие вопросы

Обсуждают сегодня

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
32
А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Дорогие любители Прекрасной Джулии! Есть кто-то имеющий практический опыт построения ML для Систем Управления? Нам нужно сделать нейросеть для автоматической подстройки пара...
Roman Timo
4
С той же поддержкой Android в тулчейне, если кому интересно. На Swift Forums шло убогое обсуждение всякой херни годами, но ничего годного так и не появлялось. Пришел vgorloff ...
iMike
1
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Приветствую ребята,у меня база есть,прорешал много задач с литкода,там деревья,списки, бэктрэкинг и все остальное,что мне сейчас делать?есть может куда устроиться поработать,е...
Aקuст Lеתסuд Aקuст Lеתסuд
5
Всех приветствую. Направьте меня в нужное русло. Постепенно переписываю проект с delphi на lazarus. Приложение - обычный windows/linux клиент для бд firebird. Тут все хорошо. ...
Mishutka
4
Anybody want this chat app? If anybody interested dm  me.. Note - Firstly payment then i send you code but i will show work on gmeet.
Rayyan Ahmad
5
Карта сайта