Похожие чаты

Всем привет. Подскажите как бороться с race condition: Ситуация следующая: - инлайн

кнопка в боте выполняет функцию, которая включает в себя изменение базы данных. а именно - модель меняет значение is_active и прибавляет значение value к другому значению в другой таблице
- если путем спама отправить несколько нажатий на эту кнопку, value прибавится к другому значению несколько раз, даже если в начале есть проверка на is_active (sqlalchemy асинхронная, бот тг также асинхронный)
Подскажите как можно разрешить проблему?

8 ответов

19 просмотров

Select for update

addlyy- Автор вопроса

statement = select(model, for_update=True).where(...) result = await self.session.execute(statement).one() result.is_active = False other_model_obj.value_sum += result.value await self.session.commit() Что-то на подобии этого будет?

addlyy
statement = select(model, for_update=True).where(....

Да можно и session.get тоже юзать

addlyy- Автор вопроса
Tishka17
Да можно и session.get тоже юзать

Я правильно понимаю что пока не будет закомичена первая сессия с транзакциями, которые вовлекают в себя model, эту model нельзя будет достать из бд, будет ошибку выплевывать?

addlyy
Я правильно понимаю что пока не будет закомичена п...

Будет висеть в ожидании, но не более какого-то таймаута

addlyy- Автор вопроса
Tishka17
Будет висеть в ожидании, но не более какого-то тай...

то есть следующие селекты следующие будут ждать комита, и уже вернут мне модель где is_active изменен перевой сессией.

addlyy
то есть следующие селекты следующие будут ждать ко...

Это дефолтное поведение для for update. Там есть ещё несколько среди которых nowait который сразу вернёт ошибку

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Anyone knows where there are some instructions or discort about failed bridge transactions ?
Jochem
21
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Also, why can’t the community have a vote/ say when it comes to initiatives like buybacks. Isn’t the point of crypto decentralisation? Don’t we deserve input as long term supp...
👨🏽‍🦰
13
Привет)) уже кажется эту тему перемусолили, но вот я так и не понял. Я сейчас сижу на 27дюймов 2к мониторе. На Актуальной макоси, если я куплю 27д 4к монитор: - будет ли изобр...
Vladislav Piskunov
16
any reference of this implementation?
BitBuddha
29
Hi guys, any problem with Pulsebrige? Trying to transfer from wETH to ETH. First it tells me to connect my metamask "through mobile app" not desktop. Then I did and confirmed ...
Snowflakecrypto
13
Страшнейшая правда про списки ЦБ. С первых дней жизни P2P сферы, молодые человеки, начитавшись законодательной базы и "внутренних" документов, решили, что им противостоит сер...
Foxcool
3
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Карта сайта