反向查询:一查找多,是反向查找
无外键类的具体对象.有外键的小写类名_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.Books.objects.filter(publisher_obj=publishers_obj)
#将books_obj列表里面的每一个内容拿出来,加到列表内
books_obj_list.extend(books_obj)
return render(request, 'show_publisher.html',
{"publisher_obj_list": publisher_obj_list, "books_obj_list": books_obj_list})
html模板中
<table border="1">
<thead>
<tr>
<th>序号</th>
<th>出版社名字</th>
<th>书籍</th>
</tr>
</thead>
<tbody>
{% for publisher_obj in publisher_obj_list %}
<tr>
#序号
<td>{{ forloop.counter }}</td>
{# 出版社名字 #}
<td>{{ publisher_obj.pname }}</td>
{# 书籍名字#}
<td>
循环书籍对象列表(每一个书籍都有一个对应的publisher_obj)
{% for books_obj in books_obj_list %}
判断如果这个出版社对象与书籍的出版社对象相同,获取该书籍的名字
{% if publisher_obj == books_obj.publisher_obj %}
《{{ books_obj.bname }}》
{% endif %}
{% endfor %}
{% endfor %}
</td>
‘’’’
方法二:
views 中
def show_publisher(request):
# 获取出版社对象列表
publisher_obj_list = models.Publisher.objects.all()
return render(request, 'show_publisher.html',
{"publisher_obj_list": publisher_obj_list,})
html文件中
#反向查找:通过一查找多
#无外键的具体对象(一的具体对象).有外键的小写类名(多的类名小写)_set.all()
#反向查找默认返回的是一个QuerySet对象#}
<td>
{% for book_obj in publisher_obj.books_set.all %}
《{{ book_obj.bname }}》
{% endfor %}
</td>