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

День добрый Как произвести "безопасную" операцию с SQL таблицей? К примеру есть

стандартная форма регистрации с email и паролем, на сервер отправляется запрос на создание нового пользователя с заданными данными, но перед этим в базе проверяется не зарегистрирован ли уже пользователь с таким email (в данном примере email уникальное значение строки)

Вопрос. Если параллелью несколько людей попытаются зарегистрироваться с одинаковым email адресом не произойдет ли такое что все они успешно пройдут регистрацию?
Ведь на момент их регистрации email адрес еще не будет добавлен в таблицу.

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

7 ответов

53 просмотра

https://www.php.net/manual/ru/book.pdo.php

В SQL есть транзакции и уровни изоляции этих транзакций. Стоит об этом почитать. А так, если очень кратко: по умолчанию включëн автокоммит: это значит каждый запрос будет выполняться в своей неявной транзакции. Вместо этого необходимо сделать так: 1) запустить транзакцию 2) проверить наличие строки с помощью SELECT ... FOR UPDATE 3) если еë нет, вставить такую строку SELECT ... FOR UPDATE повесит пессимистическую блокировку, что будет держать остальные запросы на эту же строку.

allpeg
В SQL есть транзакции и уровни изоляции этих транз...

блокировать надо таблицу, а не строку. Пока вы блокируете несуществующую строку, другие запросы из очереди добавят этот email. Разве нет?

Vitaliy Monashenkov
блокировать надо таблицу, а не строку. Пока вы бло...

Блокируется не несуществующая строка, а все ключи из запроса

allpeg
Блокируется не несуществующая строка, а все ключи ...

какие ключи? SELECT… FOR UPDATE — блокирует считываемые строки на чтение. Точно такую же блокировку ставит обычный UPDATE, когда считывает данные для обновления.

allpeg
В SQL есть транзакции и уровни изоляции этих транз...

Разве нельзя уровень изоляции поднять до serializable?

@Thermophoto
Разве нельзя уровень изоляции поднять до serializa...

При уровне serializable если сделать запрос на select а затем insert с двух транзакций будет одно из двух (в зависимости от того какая бд) 1) запрос на select станет блокирующим другую транзакцию 2) оба запроса на селект скажут что всё ок, но потом один из INSERT ов выкинет ошибку сериализации

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
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
Карта сайта