SQLalchemy - Использование гибридного свойства в запросахPython

Программы на Python
Ответить
Anonymous
 SQLalchemy - Использование гибридного свойства в запросах

Сообщение Anonymous »

Скажите, что у меня есть вопрос , который принадлежит к какой -то домашней работе . На вопрос можно правильно ответить, а домашнее задание передается, если все вопросы верны.class Question(Base):
__tablename__ = 'questions'
id: Mapped[int] = mapped_column(primary_key=True)
answered_correctly: Mapped["bool"] = mapped_column()
homework: Mapped["Homework"] = relationship(back_populates="questions")
homework_id: Mapped[int] = mapped_column(ForeignKey("homework.id"))

class Homework(Base):
__tablename__ = 'homework'
id: Mapped[int] = mapped_column(primary_key=True)
answered_correctly: Mapped["bool"] = mapped_column()
questions: Mapped[list["Questions"]] = relationship(
back_populates="homework", default_factory=list
)

@hybrid_property
def passed(self):
return all([question.answered correctly for question in self.questions])

Как мне заставить это работать в запросе SQL? Я знаю, что мне нужно реализовать pass.expression, но мне неясно, что именно оно должно возвращать.
У меня есть SQL-запрос, который я могу использовать для поиска домашнего задания. это не передается - нужно ли мне преобразовать этот запрос в API SQLAlchemy, и это то, что pass.expression должен вернуть?
SELECT homework.id, from homework
JOIN question on question.id = homework.id
WHERE homework.id = &1
GROUP BY homework.id
HAVING COUNT(CASE WHEN question.answered_correctly = FALSE THEN 1 END) > 0


Подробнее здесь: https://stackoverflow.com/questions/793 ... in-queries
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»