我有一个奇怪的问题。
我有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
query或 EXISTS
遍历关系的查询。
关于django - django 中的 Q 对象和 '&' 运算符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4523530/