0

我为以下功能实现了 ManyToManyField ,该功能允许用户关注其他用户以及是否关注其他用户。他们将能够检索他们的对象。

这是我的模块

 class Person(models.Model):
    user = models.ForeignKey(User)
    name = models.CharField(max_length=100, blank=True)
    image = models.FileField(upload_to="images/",blank=True)
    following = models.ManyToManyField('self', related_name='followers', symmetrical=False, blank=True, null=True)
    birthday = models.DateField(blank=True,null=True)

    def __unicode__(self):
        return self.name

 class Board(models.Model):

    user = models.ForeignKey(User)
    name = models.CharField(max_length=100)
    created = models.DateTimeField(auto_now_add=True)
    picture = models.OneToOneField('Picture',related_name='picture',blank=True,null=True)
    def __unicode__(self):
        return self.name

问题是当一个用户关注 2 个用户时。我只能检索单个用户对象而不是两个用户。

例如,我创建了 3 个用户,Jimmy、Sarah 和 Simon。莎拉跟着西蒙和吉米

Jimmy 有一个名为 Jimmy's Math Board 的板,Jimmy 英语板 Simon 有一个名为 Simon's Whiteboard 的板

问题在下面

 >>> from pet.models import *
 >>> from django.contrib.auth.models import User
 >>> user = User.objects.get(username='Sarah')
 >>> person = Person.objects.get(user=user)
 >>> sarah = Person.objects.get(user=user)
 >>> sarah.following.all()  # SARAH IS FOLLOWING JIMMY AND SIMON
 [<Person: Jimmy>, <Person: Simon>]
 >>> users = User.objects.filter(pk__in=sarah.following.all().values_list('user__pk',flat=True))
 >>> users
 [<User: Jimmy>, <User: Simon>] # I'm able to retrieve their users
 >>> board = Board.objects.filter(user=users) # when I search for their boards , I only retrieve a single user . Jimmy's board not Simon
 >>> board
 [<Board: Jimmy's Math Board>, <Board: Jimmy English Board>]
 >>> person = Person.objects.filter(user=users) 
 >>> person
 [<Person: Jimmy>]

如何检索这两个用户板?

4

1 回答 1

1

因为board = Board.objects.filter(user=users)它的过滤user期望提供一个用户。如果您要执行类似board = Board.objects.filter(user__in=users)使用__in过滤器的操作,则过滤将正确使用用户对象列表。

您还可以使用 id 的平面列表而不是像这样的对象board = Board.objects.filter(user__in=sarah.following.all().values_list('user__pk',flat=T‌​rue))

于 2013-03-24T02:54:36.617 回答