V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
fatkun
V2EX  ›  Python

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

  •  
  •   fatkun · 2013-05-29 00:13:44 +08:00 · 3075 次点击
    这是一个创建于 4198 天前的主题,其中的信息可能已经有所发展或是发生改变。


    就是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,这样只需要两个关系表了。但关联查询好像做不了。
    2 条回复    1970-01-01 08:00:00 +08:00
    adieu
        1
    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
        2
    fatkun  
    OP
       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的长一些。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4951 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 09:59 · PVG 17:59 · LAX 01:59 · JFK 04:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.