0

我有一个社会集团对象。

在每个社交集团对象中,我都有一个朋友对象列表。

每个朋友对象都有一个与其他朋友的关系对象(充满有趣的事实,比如他们何时相遇)

在这里我被卡住了。如何正确定义我的模型,以便我可以查询任何朋友对象以提取他们的共享关系对象?

我没有看到这可以简单地用像这个答案这样的双向模型来解决,因为我正在处理一个庞大且不断增长的朋友对象列表(在链接到的解决方案中,他们创建了两个不同的模型,例如friend_a和friend_b)。

我目前的方法是让关系对象看起来像下面发布的内容。我必须在我的代码中添加逻辑以防止重复的关系对象......但是这个

 class Relationship(models.Model):
     social_clique = models.ForeignKey( Social_Clique )
     friend_0 = models.ManyToManyField( Friend, related_name='friend_0' )
     friend_1 = models.ManyToManyField( Friend, related_name='friend_1' )

我觉得我缺少正确的关键字来谷歌找到这个问题的 ORM 设计模式。关于这个问题的正确描述或如何解决这个问题的任何建议?

4

1 回答 1

2

friend_x任何一个字段都是 ManyToManys是没有意义的。朋友之间的关系是ManyToMany,但Relationship本身就是多对多关系中的中介模型(故名)。所以friend_字段应该是ForeignKeys,然后使用Relationship作为through模型另外定义一个从Friend到自身的ManyToMany字段:

class Relationship(models.Model):
    social_clique = models.ForeignKey(Social_Clique)
    friend_0 = models.ForeignKey(Friend, related_name='friend_0')
    friend_1 = models.ForeignKey(Friend, related_name='friend_1')

class Friend(models.Model):
    ... other fields ...
    friends = models.ManyToManyField('Friend', through=Relationship)

现在很容易从两个朋友 (memy_friend) 转到他们的共享关系:

Relationship.objects.get(friend_0=me, friend_1=my_friend)

或者

me.friend_0.filter(friend1=my_friend)

等等,你仍然可以得到我所有的朋友:

me.friends.all()
于 2012-07-22T20:09:49.493 回答