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

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

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

12 ответов

22 просмотра

Так по 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
вторая ошибка общая

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

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта