django中orm反向查询 _set

反向查询:一查找多,是反向查找
无外键类的具体对象.有外键的小写类名_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模板中


{% for publisher_obj in publisher_obj_list %}
    
   	    #序号
        
        {# 出版社名字 #}
        
        {# 书籍名字#}
         

‘’’’
方法二:
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对象#}

        

你可能感兴趣的:(django中orm反向查询 _set)

序号 出版社名字 书籍
{{ forloop.counter }}{{ publisher_obj.pname }} 循环书籍对象列表(每一个书籍都有一个对应的publisher_obj) {% for books_obj in books_obj_list %} 判断如果这个出版社对象与书籍的出版社对象相同,获取该书籍的名字 {% if publisher_obj == books_obj.publisher_obj %} 《{{ books_obj.bname }}》 {% endif %} {% endfor %} {% endfor %} {% for book_obj in publisher_obj.books_set.all %} 《{{ book_obj.bname }}》 {% endfor %}