Похожие чаты

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

у меня есть связь 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 ответов

55 просмотров

А почему не дословно из доки? 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, но не знаю, мне кажется это не самый лучший варинат как это можно было сделать

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

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

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