原文链接:https://my.oschina.net/linktime/blog/105280
例如有一下模型
from django.db import modelsclass 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 modelsclass 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()