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

А как большниство делает в стандартеньких монолитах с регистрацией? Или

с изменением имени?
Если нагрузка небольшая - то легче забить?

Если такое мб часто, то какой-нить оптимистик лок на таблицу и ретрай? Или очередь для последовательной обработки?

5 ответов

8 просмотров

Помимо блокировок на таблицу целиком в рсубд есть ещё блокировки по полям/диапазонам. Достаточно повесить x-блокировку по почте, проверить её и осуществить запись.

чёт я не понимаю как у вас проверка вызывает лок делаете проверку селектом - нет имейла - и всё окей - персистаем пользователя в бд делаете проверку селектом - нет имейла - и всё окей - персистаем пользователя в бд даже если второму сначала сказали что такого нет мыла, и в этот момент произошла запись в бд - он отвалится потом на констрейнте в бд и точно также заворачиваем в кастомную ошибку и пишем - сорян такой уже занят в результате у пользователя два состояния - либо переходим в условно личный кабинет, потому что зарегались успешно либо перегружаем страничку с ошибкой - извините данное мыло уже занято, вот такой пароль у него)

Владимир-Наваев Автор вопроса
Evg😎
чёт я не понимаю как у вас проверка вызывает лок д...

Я не говорил, что проверка вызывает лок. Я говорил, что прийдется сделать лок, чтобы избежать ошибки аля race)

Владимир-Наваев Автор вопроса
Evg😎
чёт я не понимаю как у вас проверка вызывает лок д...

“даже если второму сначала сказали что такого нет мыла, и в этот момент произошла запись в бд - он отвалится потом на констрейнте в бд и точно также заворачиваем в кастомную ошибку и пишем - сорян такой уже занят” вот про это и был вопрос, как мне распознать эту ошибку в Spring Data, лезть и парсить SQL ошибки?

Владимир Наваев
Я не говорил, что проверка вызывает лок. Я говорил...

ну просто целиком всё в транзакцию заворачиваете "делаете проверку селектом - нет имейла - и всё окей - персистаем пользователя в бд" и да делаете лок

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

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

Есть какой-нибудь для 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
1
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
Карта сайта