gpt4 book ai didi

python - Django:改进查询集

转载 作者:太空宇宙 更新时间:2023-11-03 20:25:54 25 4
gpt4 key购买 nike

我目前有以下查询集,我想知道是否有办法将该部分 question.answers.all() 引入到 questions= 查询集中。

def get_questions_and_answers(self):
questions = (
self.request.event.surveys.get(template=settings.SURVEY_POST_EVENT)
.questions.exclude(focus=QuestionFocus.EMAIL)
.all()
)

questions_and_answers = {}
for question in questions:
questions_and_answers[question] = question.answers.all()

return questions_and_answers

models.py

class Question(TimeStampedModel[...]):
survey = models.ForeignKey(related_name='questions')
type = models.CharField([...])
focus = models.CharField([...])

class Answer(TimeStampedModel):
question = models.ForeignKey(related_name='answers')
response = models.ForeignKey(related_name='answers')
answer = models.TextField([...])

class Survey(TimeStampedModel):
event = models.ForeignKey(related_name='surveys')
template = models.CharField([...])

最佳答案

是的,您可以喜欢下面的小改动:

questions = (
self.request.event.surveys.get(template=settings.SURVEY_POST_EVENT)
.questions.exclude(focus=QuestionFocus.EMAIL)
.all().prefetch_related('answers')
)

在这里,对于每个问题,您都会得到答案

有关更多信息,请点击 prefetch_related

关于python - Django:改进查询集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57828680/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com