反向查询:一查找多,是反向查找
无外键类的具体对象.有外键的小写类名_set
无外键类是一,有外键是多.
一的具体对象.多的类名小写_set 查到一的具体对象下的所有多的对象
eg:
一个出版社对应多本书,以出版社为标准查找书,反向查找。
一个出版社对象.书类_set 查到出版社下的书籍对象,这个书籍对象默认是一个QuerySet对象
查到一个出版社具体对象下的所有的书
]
实例演示
#出版社类(表)
class Publisher(models.Model):
pid = models.AutoField(primary_key=True)
pname = models.CharField(max_length=32)
#书籍类(表)
class Books(models.Model):
bid = models.AutoField(primary_key=True)
bname = models.CharField(max_length=32)
publisher_obj = models.ForeignKey('Publisher')
#展示出版社方法一:
views内:
def show_publisher(request):
# 获取出版社对象列表
publisher_obj_list = models.Publisher.objects.all()
# 获取书籍,通过书籍中的外键对象publisher_obj
# 循环这个出版社对象列表,在书籍表中匹配每一个出版社对象,匹配到就返回书籍对象列表,没有就是空的对象列表,该书籍对象,有具体的出版社对象
books_obj_list = []
for publishers_obj in publisher_obj_list:
#获取到books_obj可能是一个列表
books_obj = models.