class Author(models.Model):
'''作者表'''
name = models.CharField(max_length=32)
book = models.ManyToManyField(to="Book")
# def __str__(self):
# return self.name
class Book(models.Model):
'''书表'''
title = models.CharField(max_length=32)
price = models.CharField(max_length=32)
publish = models.ForeignKey(to="Publish")
# def __str__(self):
# return self.title
#egon出版过的书的出版社信息
class Publish(models.Model):
'''出版社'''
address = models.CharField(max_length=32)
# def __str__(self):
# return self.address
# author = models.Author.objects.all() #查询到所有的作者对象queryset author多对多book
# book = models.Book.objects.all() # 查询到所有的书籍对象queryset book多对一publish
# publish = models.Publish.objects.all() #查询到所有的出版社对象queryset
# #================================================字段查询============================================================
# for te in author:
# print("======author",te.name) #查询自己表内的信息
# print("======author_book",te.book.first().title) #通过自己查找多对多的字段
# print("======author_book_publish",te.book.first().publish.address) #通过自己查找多对多的字段,然后查找多对一字段
# for te in book:
# print("========tetetet",te)
# print("======book",te.title,te.price) #查询自己表内的信息
# print("========book_publish",te.publish.address) #通过自己查询多对一的出版社表
# print("==========book_author",te.author_set.first()) #通过自己反向查找作者姓名
# for te in publish:
# print("=====publish",te.address) #查询自己表内的信息
# print("=====publish_book",te.book_set.first().title)
# print("=======publish_book_author",te.book_set.first().author_set.first())
#
#
# author_book_publish = author.first().book.all().first().title
# print("==================================",author_book_publish)
# #============================================双下划线正向查询===========================================================
# author = models.Author.objects.all() # 查询到所有的作者对象queryset author多对多book
# book = models.Book.objects.all() # 查询到所有的书籍对象queryset book多对一publish
# publish = models.Publish.objects.all() # 查询到所有的出版社对象queryset
# book_title = author.filter(name="egon").values("book__title") #在author表中查book标的title
# book_price = author.filter(name="egon").values("book__price") #在author表中查book表的price
# book_publish_address = author.filter(name="egon").values("book__publish__address") #在author表中二次关联查找出版社
# print("============book_title|book_price",book_title,book_price)
# print("============book_publish_addredd",book_publish_address)
# #============================================双下划线反向查询===========================================================
# book_title = publish.filter(address="北京").values("book__title")
# book_price = publish.filter(address="北京").values("book__price")
# publish_book = publish.filter(address="北京").values("book__author")
# publish_author_book = publish.filter(address="北京").values("book__author__name")
# print("============book_title|book_price",book_title,book_price)
# print("============publish_book",publish_book)
# print("============publish_author_book",publish_author_book)
########################################################################################################################
转载于:https://blog.51cto.com/52770825/1980887