Похожие чаты

Привет, пытаюсь решить проблему, никак не получается, помогите пожалуйста. Приложение

FastAPI использующее SQLAlchemy_2.0
Есть функция возвращающая Shift c загруженными предварительно связанными Member.user и Member.reports. Которая использует для этого рекомендованный метод selectinload Необходимо изменить её так, чтобы возвращались связанные данные только тех Member, у которых Member.user.is_test_user == False

Модели:

class Shift(Base):
__tablename__ = "shifts"
reports = relationship("Report", back_populates="shift")
members = relationship("Member", back_populates="shift")

class User(Base):
__tablename__ = "users"
members = relationship("Member", back_populates="user")
is_test_user = Column(Boolean, default=False, nullable=False)

class Member(Base):
__tablename__ = "members"
status = Column(String(10))
user_id = Column(UUID(as_uuid=True), ForeignKey(User.id), nullable=False)
user = relationship("User", back_populates="members")
shift_id = Column(UUID(as_uuid=True), ForeignKey(Shift.id), nullable=False)
shift = relationship("Shift", back_populates="members")
reports = relationship("Report", back_populates="member")

class Report(Base):
__tablename__ = "reports"
shift_id = Column(UUID(as_uuid=True), ForeignKey(Shift.id), nullable=False)
shift = relationship("Shift", back_populates="reports")
member_id = Column(UUID(as_uuid=True), ForeignKey(Member.id), nullable=False)
member = relationship("Member", back_populates="reports")

Функция:

async def get_with_members(self, id: UUID, member_status: Optional[str]) -> Shift:
member_stmt = Shift.members
if member_status:
member_stmt = member_stmt.and_(Member.user == member_status)
statement = (
select(Shift)
.where(Shift.id == id)
.options(selectinload(Shift.members).selectinload(Member.user))
.options(selectinload(Shift.members).selectinload(Member.reports))
)
request = await self._session.execute(statement)
return request.scalars().first()

Попытки изменить member_stmt == Shift.members.and_(Member.user.is_test_user==False), вызывают исключение: Neither 'InstrumentedAttribute' object nor 'Comparator' object associated with Member.user has an attribute 'is_test_user'. Возможно необходимо использовать вместо selectinload() обычный join() совместно contains_eager() или subqueryload() ?

7 ответов

41 просмотр

Кол на пастбин или гист, а то много, тут не воспринимается

Eugene Che
https://pastebin.com/px0Pn7JY

Я бы сделал джоином

Eugene Che
https://pastebin.com/px0Pn7JY

А не, ты хочешь чтобы при этом запросе в релейшене были отфильтрованы по полю?

Eugene-Che Автор вопроса

Да необходимо отсечь тех Members у которых есть связь с User, который, в свою очередь имеет поле User.is_test_user == True

Eugene-Che Автор вопроса
Fred Bernardo
Тогда да, джоин и два условия в where

statement = ( select(Shift) .join(Shift.members) .where(Shift.id == id, User.is_test_user == False) .options(contains_eager(Shift.members)) ) Изменил statement таким образом, теперь раизится greenlet_spawn has not been called; can't call await_only() here. Was IO attempted in an unexpected place.

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

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

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
Карта сайта