Похожие чаты

Добрый день. Опишу ситуацию: 2 таблицы, в одной из них

- счетчик ошибок (поле count) . Как только счетчик больше порога - в первой  таблице поле enabled нужно переставить в значение false.

Создавать тригер не особо хочу, поскольку синтаксис может меняться в зависимости от субд. Да и сама операция создания подразумевает написания sql-запроса  Думаю в сторону event.listens_for.

Правилен ли подход, или можно вообще обойтись и без тригеров и листенеров путем джойна таблиц и выбора тех строк, которые ниже порога?

9 ответов

22 просмотра

А у тебя много откуда этот count меняется?

Brаl Brаl-Bral 🏳️‍🌈👠 Автор вопроса
Айван
А у тебя много откуда этот count меняется?

Через asyncio.gather выполняются таски. Порядка 50-70. И в случае ошибки, счётчик ошибок нужно увеличить.

Brаl Brаl Bral 🏳️‍🌈👠
Через asyncio.gather выполняются таски. Порядка 50...

Я бы предпочел явно прописать def add_failure(model): model.count += 1 if model.count > X: model.enabled = False

Brаl Brаl Bral 🏳️‍🌈👠
Через asyncio.gather выполняются таски. Порядка 50...

указал вот так, имеет право на жизнь, если в приложении использется и класический и декларативный способ? target_metadata = models.metadata target_metadata = auth_models.Base.metadata

Brаl Brаl-Bral 🏳️‍🌈👠 Автор вопроса
Айван
Я бы предпочел явно прописать def add_failure(mode...

понял. ну это имеет место быть, если 2 поля находятся в одной таблице.

Brаl Brаl Bral 🏳️‍🌈👠
понял. ну это имеет место быть, если 2 поля находя...

В любом случае можно сделать def add_failure(model, model2): model.count += 1 if model.count > X: model2.enabled = False Раз уж предполагается что count превысивший X должен менять enabled

Brаl Brаl-Bral 🏳️‍🌈👠 Автор вопроса
Айван
В любом случае можно сделать def add_failure(model...

Идею понял. Спасибо. А чем листенеры плохи?

Brаl Brаl Bral 🏳️‍🌈👠
Идею понял. Спасибо. А чем листенеры плохи?

Просто не нравится идея выполнения бизнес-правил завязываясь на механизмы SQLAlchemy. Эвенты допускаю, но предпочел бы реализовать их самостоятельно model.count += 1 event_observer.publish(SomethingFailedEvent(..., fails_count=model.count, model2_id=model.model2_id)) def fails_handler(event: SomethingFailedEvent, model2_repo): if event.fails_count > X: model2 = model2_repo.get_model(event.model2_id) model2.enabled = False

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта