python - 如何过滤 Django QuerySet 的相关字段' 'all' 或 'none'

标签 python django django-queryset django-orm

例如,我有一个模型 Cat,它有一个来自 Life 的反向 ForeignKey

class Life(models.Model):
    state = models.CharField(choices=('alive', 'dead', 'unknown')
    cat = models.ForeignKey('animals.Cat', related_name="lives")


class Cat(models.Model):
     name = models.CharField(max_length=12)
     cat_type = models.CharField(choices=('normal', 'schroedinger')
     ...

我如何获得一个QuerySetCat 没有失去他们的生命? IE。 所有他们的生活要么处于“活着”状态,要么是 cat_type“schroedinger”并且没有任何生活处于“死亡”状态)

最佳答案

我有一段时间没有使用这个 API,但我相信这会完成工作:

from django.db.models import Q

normal_and_alive = Q(cat_type="normal") & ~Q(lives__state__in=["dead", "unknown"])
schroedinger_and_not_dead = Q(cat_type="schroedinger") & ~Q(lives__state="dead")

cats = Cat.objects.filter(normal_and_alive | schroedinger_and_not_dead)

有关 complex lookups with the Q() object 的 django 文档,请参阅文档

旁白:这只会执行一个数据库查询

关于python - 如何过滤 Django QuerySet 的相关字段' 'all' 或 'none',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17939139/

相关文章:

django - 在 django 模板中迭代用户

Python fabric "local"函数不遵守环境变量 DJANGO_SETTINGS_MODULE

sql - Django sql排序依据

python - Django 嵌套查询集

python - 使用 Python 请求复制 Curl 命令

python - 我如何在 flask 中检查用户填写的表单字段

python - 与sympy逐步分化

python - Django:如何在管理中显示文本字段之前修改它

django - 在已过滤的查询集上使用 Django 自定义管理器功能

Python - 向列表中的项目添加信息,从而创建元组列表