Похожие чаты

Всем привет, не пойму один момент с асинхронной алхимией. Когда

у меня есть связь Many To One между моделями и я пытаюсь обратиться к списку связанных обьектов, то есть к type_writer_infos в модели PortfolioInfo, то получаю ошибку.

class PortfolioInfo(Base):
__tablename__ = 'portfolio_info'

id: Mapped[uuid.uuid4] = mapped_column(UUID(as_uuid=True),
primary_key=True,
default=uuid.uuid4)
owner_name: Mapped[str] = mapped_column(String(40),
nullable=False)
type_writer_infos: Mapped[list['TypeWriterInfo']] = relationship(back_populates='portfolio_info')



class TypeWriterInfo(Base):
__tablename__ = 'type_writer_info'

id: Mapped[uuid.uuid4] = mapped_column(UUID(as_uuid=True),
primary_key=True,
default=uuid.uuid4)
info: Mapped[str] = mapped_column(String(150),
nullable=False)
portfolio_info_id: Mapped[uuid.uuid4] = mapped_column(ForeignKey('portfolio_info.id'))
portfolio_info: Mapped['PortfolioInfo'] = relationship(back_populates='type_writer_infos')

def __repr__(self):
return f'Info: {self.info}'


вот модели.

Вот пример

async def create_portfolio_info(self):
info = PortfolioInfo(
owner_name='Oleg Kuzmenko'
)
async with self.session.begin():
self.session.add(info)
lst = info.type_writer_infos
await self.session.commit()
print(lst)
return info

здесь всё ок, я внутри транзакции забираю список связанных обьектов и когда делаю принт ошибок нету, выдает список.

Но, если

async def create_portfolio_info(self):
info = PortfolioInfo(
owner_name='Oleg Kuzmenko'
)
async with self.session.begin():
self.session.add(info)
await self.session.commit()
lst = info.type_writer_infos
print(lst)
return info

я выношу это за пределы транзакции, то мне выдает

sqlalchemy.exc.MissingGreenlet: greenlet_spawn has not been called and asyncio event loop is already running; can't call await_fallback() here. Was IO attempted in an unexpected place? (Background on this error at: https://sqlalche.me/e/20/xd2s)

я и lazy='selectin' прописывал но не помогло. Вопрос, мне получается чтобы получать связанные обьекты, нужно всегда получать их внутри транзакции?

3 ответов

50 просмотров

А почему не дословно из доки? https://docs.sqlalchemy.org/en/20/orm/extensions/asyncio.html#preventing-implicit-io-when-using-asyncsession stmt = select(A).options(selectinload(A.bs))

Ты отключал expire_on_commit?

Oleg-Kuzmenko Автор вопроса

async def create_portfolio_info(self): info = PortfolioInfo( owner_name='Oleg Kuzmenko' ) async with self.session.begin(): self.session.add(info) await self.session.commit() await self.session.refresh(info, attribute_names=['type_writer_infos']) print(info.type_writer_infos) return info решил это с помощью session.refresh, но не знаю, мне кажется это не самый лучший варинат как это можно было сделать

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

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

Hey everyone! I won’t focus too much on what this person said (it’s clear they don’t understand the scope of what TF and TELOSX are achieving), but I’ll put it simply for thos...
Ana Ojeda
2
как правильно удалить сддм? прописал в etc/portage.use/plasma-meta -sddm , но при обновлении юзов мне предлагает поставить lightdm (ещё лучше 😡), добавил туда - display-manage...
REDis
25
Telos is at a pivotal moment. While ambitious projects like zkEVM and SNARKtor have shown promise, the delay in delivering EVM 2.0—a cornerstone of the ecosystem—is a growing ...
Trinidad
8
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
#include <stdio.h> #include <stdlib.h> #include <time.h> void mass_first_generate(int mass[5][7]) {     for (int N = 0; N < 5; N++) {         for (int A = 0; A < 7; A++) {   ...
Чувак
6
Всем привет! Решаю 99 OCaml Problems и столкнулся со следующей проблемой (прошу палками не забивать, я OCaml практически не трогал до этого момента): open OUnit2 let create_...
К|/|pи/\/\ 6е3yглbIи
2
Except the wealthiest, people that buy crypto want to "cash out" at the end of the day, one way or another. Converting to fiat is craziness, converting to BTC is unwise. Hold ...
Erdelanax
2
Hello guys, hope you can help me with a quick question. I've staked some ZIL using Atomic Wallet some while ago and wanted to claim my rewards and unstake it. Atomic Wallet sa...
Martin | #bornbrave
14
Ready for some fun AND a chance to win TKO Tokens? Join us for exciting minigames in our Telegram group! 🕒 Don’t miss out—games start on today 25 October 2024, at 8 PM! Ge...
Milkyway | Tokocrypto
255
https://www.linkedin.com/posts/ugama-benedicta-kelechi-codergirl-103041300_mobiledevelopment-fluttertraining-handsonlearning-activity-7263445699227254784-IdHB?utm_source=share...
CoderGirl
16
Карта сайта