首页 > 其他 > 详细

django manytomany

时间:2014-08-07 18:34:11      阅读:390      评论:0      收藏:0      [点我收藏+]

转载: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()

django manytomany,布布扣,bubuko.com

django manytomany

原文:http://www.cnblogs.com/yunsicai/p/3897421.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!