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

Всем привет! В моем приложении есть код, который делает выборку в

бд:
SELECT * FROM participants WHERE name = :name
Далее, при условии отсутствия такого участника, выполняется INSERT INTO ...

Т.к. данные операции не атомарны, это приводит к наличию race condition, который позволяет быстро отправив два последовательных запроса, зарегистрировать одного участника дважды. Псевдокод код воспроизведения такой баги:
let result1 = contestService.handleAddParticipantRequest(
new AddParticipantRequest('iddqd')
);
let result2 = contestService.handleAddParticipantRequest(
new AddParticipantRequest('iddqd')
);

let result1 = await voteResult1;
let result2 = await voteResult2;

expect(result1.isSuccess).to.be.true;
expect(result2.isSuccess).to.be.false;

Может ли кто-то рассказать об основных путях решения такой проблемы? Или может есть какое-то средство в языке/популярная либа для борьбы с этим?

1 ответов

8 просмотров

Сделать name unique

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

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

Доброй ночи. Вопрос знатокам. Имеется некая таблица, результат которой выведен в DBGrid на форме. И есть форма, с помощью которой можно как добавить запись, так и отредактиров...
Евгений
27
а всё почему? потому что ассемблер в отличии от яву порождает множество пагубных привычек, среди которых например можно отметить использование глобальных переменных для всего ...
Mixail Frolov
35
анрей С какой целью зашёл?
КТ315
42
Кто нибудь из участников чата пишет на ассемблере под GNU/Linux?
Spiker01
24
я часов 15 назад начал пытаться написать хоть что-то напоминающее ос и у меня есть проблема, которую я пытаюсь решить последние часов 5: есть крч 2 исходника с минимальным код...
Al1to
17
Всем привет ребят! Мб кто-то сталкивался? adminСomponents .get("searchСomponents", use: searchComponents) .openAPI( summary: ...
Admin Adminov
2
Кстати вопрос. Проанализировав свои проекты я понял, что в наиболее ценных из них Асм использовался для организации real-time процессов (внутри DOS). А какие есть способы сего...
Alexander Morozov
18
Я не очень много работал с потоками, тут возник вопрос - если будет одновременный доступ к памяти из двух разных потоков, это само по себе приведет к ошибке?
The Bird of Hermes
25
Насколько моя реализация Exercise 1 плохая? data MessageType = Info | Warning | Error Int deriving (Show, Eq) type TimeStamp = Int data LogMessage = LogMessage ...
= ?
6
а вот интересный вопрос появляется: допустим у нас есть приложение с системой модулей. Будет ли считаться система модуль+прога ассемблерной программой если: а) Прога на Си, м...
Mixail Frolov
29
Карта сайта