10

models.py

class Category(models.Model):
    name = models.CharField(max_length=50)

    def __unicode__(self):
        return self.name

class Gender(models.Model):
    name = models.CharField(max_length=50)

    def __unicode__(self):
        return self.name

class Post(models.Model):
    name = models.CharField(max_length=50)
    categories = models.ManyToManyField(Category)
    genders = models.ManyToManyField(Gender)

    def __unicode__(self):
        return self.name

view.py:

def index(request):
    posts = Post.objects.filter(genders=1)

    categories = Category.objects.filter(post__genders=1)
                                 .exclude(post=None).order_by('-sort')

性別が1に等しい投稿が3つあるのに、なぜ同じカテゴリを3回取得するのですか?カテゴリは1回だけ必要です。「個別に選択」のように選択します。どうすればよいですか?

4

1 に答える 1

24

クエリセットにを添付してみました.distinct()か?

categories = Category.objects.filter(post__genders=1).exclude(post=
      None).order_by('-sort').distinct()
于 2010-09-13T08:10:38.507 に答える