假设我有一个像这样的Django模型:
class Person(models.Model):
name = models.CharField(max_length=64, blank=True, null=True)
age = models.IntField(blank=True, null=True)
class Friendship(models.Model):
person1 = models.ForeignKey('Person', related_name="person1")
person2 = models.ForeignKey('Person', related_name="person2”)
对于Person my_guy,我如何有效地找到所有与my_guy没有友谊的人?
我可以做这样的事情,但必须有一个更加数据库友好和有效的方式:
friends = []
for friendship in Friendships.objects.filter(Q(person1=my_guy) | Q(person2=my_guy)):
if friendship.person1 == my_guy:
friends.append(friendship.person2)
else:
friends.append(friendship.person1)
non_friends = []
for p in Persons.objects.all():
if p not in friends:
non_friends.append(p)
print non_friends
如果需要,我愿意更改模型,但如果有一种有效的方法可以使用现有模型,我会喜欢它。
答案 0 :(得分:0)
我明白了。最简单的方法是用多对多关系重塑模型:
class Person(models.Model):
name = models.CharField(max_length=64, blank=True, null=True)
age = models.IntField(blank=True, null=True)
class Friendship(models.Model):
members = models.ManyToManyField(Person)
然后就这么简单:
non-friends = Person.objects.exclude(friendship__members=person).exclude(id=person.id)