首页 > 代码库 > django manytomany
django manytomany
转载:http://my.oschina.net/u/572994/blog/105280
例如有如下模型
models.py
?
1 2 3 4 5 6 7 | from django.db import models class person(models.Model): name = CharField(max_length = 30 ) class book(models.Model): auther = ManyToManyField(person)<span>< / span> |
假设p为一个person对象,b为一个book对象
则
?
1 2 3 4 5 6 7 8 9 10 11 | #添加关联 b.auther.add(p) #去除关联 b.auther.remove(p) #返回所有作者 b.auther. all () #反向查询,返回这个人写的所有书,book即为反向查询的模型名 p.book_set. all () |
如果在models.py中
?
1 2 3 4 5 6 7 8 9 | from django.db import models class person(models.Model): name = CharField(max_length = 30 ) class book(models.Model): #当关联同一个模型的字段大于一个时,要使用related_name参数来指定表名 auther = ManyToManyField(person,related_name = "auther" ) translater = ManyToManyField(person,related_name = "translater" ) |
此时反向查询p.book_set.all()不可用,取而代之的为
?
1 2 3 4 5 | #返回该人写的所有书,book_set被related_name中指定的表名代替 p.auther. all () #返回该人翻译的所有书 p.translater. all () |
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。