请教django多对多model设计的问题

2013-05-29 00:13:44 +08:00
 fatkun


就是A,B都和host,group关联,他们的关系是多对多关系。也就是 1个A对应多个host或group,1个host对应多个A,B。

由于还需要在group和A,B的关系中存储一个额外的值,所以单独建了一个关系表。
model大概如下

class A
class B
class Host
class Group

class A_host_rel
A_id = models.ForigenKey(A)
host_id = models.ForigenKey(Host)

class B_host_rel
B_id = models.ForigenKey(B)
host_id = models.ForigenKey(Host)

class A_group_rel
A_id = models.ForigenKey(A)
group_id = models.ForigenKey(Group)
num = xxx

class B_group_rel
B_id = models.ForigenKey(B)
group_id = models.ForigenKey(Group)
num = xxx

这样做之后。。问题是:
关系表非常多,维护关系非常蛋疼。。而且很容易写错。。
是否有更好的设计方法?操作数据库更容易些?我觉得还有一个方案是关系表用ContentType,关联A和B,这样只需要两个关系表了。但关联查询好像做不了。
3094 次点击
所在节点    Python
2 条回复
adieu
2013-05-29 00:23:35 +08:00
在A和B上面用ManyToManyField指向host,就可以避免写A_host_rel和B_host_rel,变为让Django自动管理

因为A和B到group的关系有一个额外的num字段,所以A_group_rel和B_group_rel是无法避免的。只是还是可以用ManyToManyField配合上through参数,来指定A_group_rel和B_group_rel是中间表。这样可以支持ManyToManyField的基本查询方法。详见 https://docs.djangoproject.com/en/dev/topics/db/models/#extra-fields-on-many-to-many-relationships
fatkun
2013-05-29 00:50:25 +08:00
@adieu thx,
看了文档,那A_group_rel还是必须得自己创建,只是查询可以用ManyToManyField的方法是吗?

我不使用ManyToManyField,还是可以通过A.objects.filter(a_group_rel__A__id=1)查找这个A所有的group,不过好像比ManyToManyField的长一些。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/70459

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX