11

我有一个奇怪的问题。

我有 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() 的文章,因为它会收集每篇文章 2x,因为它们都有两个标签。

但是,使用此查询:

actionsAll = Articles.objects.filter((Q(tags__name__exact="tag1") & Q(tags__name__exact="tag2"))).distinct()

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

4

2 回答 2

1

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

于 2010-12-24T01:18:15.590 回答
1
** import Q from django
from *models import SuperUser, NameUser
import operator

# we do not know the name in the superhero
super_users = SuperUser.objects.all()
q_expressions = [Q(username=user.username) for user in super_users]
# we have bind super_hero with user
name_superheroes_qs = models.NameUser.objects.filter(reduce(operator.or_, q_expressions))
于 2016-05-06T14:28:57.687 回答