@magine
        
        2014-11-24T09:38:15.000000Z
        字数 782
        阅读 1893
    Django
例如有如下模型
# models.pyfrom 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.pyfrom 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()