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) ########################################################################################################################
原文地址:http://52770825.blog.51cto.com/13217087/1980887