Похожие чаты

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

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

8 ответов

22 просмотра

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 который сразу вернёт ошибку

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
@Benzenoid can you tell me the easiest, and safest way to bu.y HEX now?
Živa Žena
20
This is a question from my wife who make a fortune with memes 😂😂 About the Migration and Tokens: 1. How will the old tokens be migrated to the new $LGCYX network? What is th...
🍿 °anton°
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
What is the Dex situation? Agora team started with the Pnetwork for their dex which helped them both with integration. It’s completed but as you can see from the Pnetwork ann...
Ben
1
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Anyone knows where there are some instructions or discort about failed bridge transactions ?
Jochem
21
@lozuk how do I get my phex copies of my ehex from a atomic wallet, to move to my rabby?
Justfrontin 👀
11
Карта сайта