原文链接:https://my.oschina.net/linktime/blog/105280
例如有一下模型
from django.db import models class person(models.Model): name = CharField(max_length=30) class book(models.Model): auther = ManyToManyField(person)
假设p为一个person对象,b为一个book对象
则
#添加关联 b.auther.add(p) #去除关联 b.auther.remove(p) #返回所有作者 b.auther.all() #反向查询,返回这个人写的所有书,book即为反向查询的模型名 p.book_set.all()
如果在models.py中
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()不可用,取而代之的为
#返回该人写的所有书,book_set被related_name中指定的表名代替 p.auther.all() #返回该人翻译的所有书 p.translater.all()