gpt4 book ai didi

django - 过滤 django 查询集,包括 manytomany 字段中的特定对象

转载 作者:行者123 更新时间:2023-12-03 18:23:39 26 4
gpt4 key购买 nike

这是我的模型,

class Age(models.Model):
layer = models.CharField(max_length=50)
order = models.PositiveIntegerField()
...
class Course(models.Model):
target_age = models.ManyToManyField('Age')
...

如何获取包含特定年龄的类(class)查询集?
意见:
request_courses = Course.objects.filter(target_age ...

最佳答案

你的问题有点含糊。首先,阅读 querying across relationships. 上的文档

如果您只想获得与这些相关的类(class) Age具有特定字段值:

Course.objects.filter(target_age__FIELD=...)

其中 FIELD 是您 Age 中的字段要查询的模型。

或者,如果您有 Age对象,并且您想要获取与特定 Age 实际相关的所有类(class)对象,你需要:
age = Age.objects.get(...)
courses = Course.objects.filter(target_age=age)

或者,如果您想获得与至少一种可能相关的类(class) Age的:
ages = Age.objects.filter(...)
courses = Course.objects.filter(target_age__id__in=ages.values_list('id'))

编辑

最后一个例子是使用 the in lookup

关于django - 过滤 django 查询集,包括 manytomany 字段中的特定对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10037985/

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