gpt4 book ai didi

django - django 中的 Q 对象和 '&' 运算符

转载 作者:行者123 更新时间:2023-12-04 02:28:35 24 4
gpt4 key购买 nike

我有一个奇怪的问题。

我有3个对象。全部都一样

class Articles(models.Model):
owner = models.ForeignKey(Author)
tags = models.ManyToManyField('Tag')


class Tag(models.Model):
name = models.CharField(max_length=255)

所以我有 3 篇文章。使用所有相同的标签:'tag1' 和 'tag2'

我有疑问
actionsAll = Articles.objects.filter((Q(tags__name__exact="tag1") | Q(tags__name__exact="tag2"))).distinct()

这给了我所有的文章。它将返回 6 篇没有 distinct() 的文章,因为它会收集每篇文章 2 倍,因为它们都有两个标签。

但是有了这个查询:
actionsAll = Articles.objects.filter((Q(tags__name__exact="tag1") & Q(tags__name__exact="tag2"))).distinct()

这给我没有文章。
由于文章包含两个标签,它应该全部返回它们,不是吗?

最佳答案

如果您查看它生成的 SQL,您将看到它会检查同一标签是否具有两个名称。您需要的是一个 IN queryEXISTS遍历关系的查询。

关于django - django 中的 Q 对象和 '&' 运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4523530/

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