正反向/多表查询
正反向
# 正向 # 反向 外键字段在我手上那么,我查你就是正向 外键字段如果不在手上,我查你就是反向 book >>>外键字段在书那儿(正向)>>> publish publish >>>外键字段在书那儿(反向)>>>book 一对一和多对多正反向的判断也是如此 """ 正向查询按字段 反向查询按表名小写 _set ... """
多表查询
# 1.查询书籍主键为1的出版社 # book_obj = models.Book.objects.filter(pk=1).first() # # 书查出版社 正向 # res = book_obj.publish # print(res) # print(res.name) # print(res.addr) # 2.查询书籍主键为2的作者 # book_obj = models.Book.objects.filter(pk=2).first() # # 书查作者 正向 # # res = book_obj.authors # app01.Author.None # res = book_obj.authors.all() # <QuerySet [<Author: Author object>, <Author: Author object>]> # # print(res) # 3.查询作者jason的电话号码 # author_obj = models.Author.objects.filter(name='jason').first() # res = author_obj.author_detail # print(res) # print(res.phone) # print(res.addr) """ 在书写orm语句的时候跟写sql语句一样的 不要企图一次性将orm语句写完 如果比较复杂 就写一点看一点 正向什么时候需要加.all() 当你的结果可能有多个的时候就需要加.all() 如果是一个则直接拿到数据对象 book_obj.publish book_obj.authors.all() author_obj.author_detail """ # 4.查询出版社是东方出版社出版的书 # publish_obj = models.Publish.objects.filter(name='东方出版社').first() # 出版社查书 反向 # res = publish_obj.book_set # app01.Book.None # res = publish_obj.book_set.all() # print(res) # 5.查询作者是jason写过的书 # author_obj = models.Author.objects.filter(name='jason').first() # 作者查书 反向 # res = author_obj.book_set # app01.Book.None # res = author_obj.book_set.all() # print(res) # 6.查询手机号是110的作者姓名 # author_detail_obj = models.AuthorDetail.objects.filter(phone=110).first() # res = author_detail_obj.author # print(res.name) """ 基于对象 反向查询的时候 当你的查询结果可以有多个的时候 就必须加_set.all() 当你的结果只有一个的时候 不需要加_set.all() 自己总结出 自己方便记忆的即可 每个人都可以不一样 """
联表查询(基于双下划线)
# 基于双下划线的跨表查询 # 1.查询jason的手机号和作者姓名 # res = models.Author.objects.filter(name='jason').values('author_detail__phone','name') # print(res) # 反向 # res = models.AuthorDetail.objects.filter(author__name='jason') # 拿作者姓名是jason的作者详情 # res = models.AuthorDetail.objects.filter(author__name='jason').values('phone','author__name') # print(res) # 2.查询书籍主键为1的出版社名称和书的名称 # res = models.Book.objects.filter(pk=1).values('title','publish__name') # print(res) # 反向 # res = models.Publish.objects.filter(book__id=1).values('name','book__title') # print(res) # 3.查询书籍主键为1的作者姓名 # res = models.Book.objects.filter(pk=1).values('authors__name') # print(res) # 反向 # res = models.Author.objects.filter(book__id=1).values('name') # print(res) # 查询书籍主键是1的作者的手机号 # book author authordetail # res = models.Book.objects.filter(pk=1).values('authors__author_detail__phone') # print(res) """ 你只要掌握了正反向的概念 以及双下划线 那么你就可以无限制的跨表 """