本文主要是介绍Django之ORM跨表查询、join查询、聚合查询、分组查询,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
ORM跨表查询、join查询、聚合查询、分组查询、FQ查询
- 1、基于对象的跨表查询(sql语句:子查询)
- 1.1 一对多
- 1.2 多对多
- 1.3 一对一
- 1.4 related_name 覆写 FOO_set
- 2、基于双划线的跨表查询(sql:join语句)
- 2.0 join简介
- 2.1 一对多
- 2.2 多对多
- 2.3 一对一
- 2.4 related_name 覆写 FOO_set
- 3、 跨表查询进阶
- 3.1 多个跨表嵌套
- 3.2 连续跨表查询
- 4、F查询 与 Q查询
- 4.0 Book表模型
- 4.1 F 查询
- 4.2 Q 查询
- 5、聚合与分组查询
- 5.1 聚合查询
- 5.2 分组查询
- 5.2.1 分组介绍
- 5.2.2 分组 类 实现
- 5.2.3 查询练习
- 附录 git
跨表查询分为两类: 基于对象查询(子查询) 基于双下划线查询(join查询)
1、基于对象的跨表查询(sql语句:子查询)
子查询: 基于一个查询结果作为另一个查询的条件
1.1 一对多
"""
正向查询:多找一,按字段
反向查询:一找多,按表名称小写_set,其中set表示集合的意思
"""
- 正向查询(按字段)
# 查询西游记出版社的名字和邮箱
book = Book.objects.get(title='西游记')
print(book.publish.name)
print(book.publish.email)
本质上翻译两条sql如下:
(0.000) SELECT "book_book"."id", "book_book"."title", "book_book"."pub_date", "book_book"."price", "book_book"."publish_id" FROM "book_book" WHERE "book_book"."title" = '西游记' LIMIT 21; args=('西游记',)
# 小橘子出版社
(0.000) SELECT "book_publish"."id", "book_publish"."name", "book_publish"."city", "book_publish"."email" FROM "book_publish" WHERE "book_publish"."id" = 3 LIMIT 21; args=(3,)
# 222@666.com
- 反向查询(按表名:book_set,按 表名称小写_set, set是集合的意思,返回queryset集合)
# 查询小橘子出版社的所有书籍
pub = Publish.objects.get(name='小橘子出版社')
print(pub.book_set.all()) # 与这个出版社关联的所有书籍,即返回一个queryset
# <QuerySet [<Book: 西游记>, <Book: 赳赳老秦>]>print(pub.book_set.values('title', 'price'))
# <QuerySet [{'title': '西游记', 'price': Decimal('199.00')}, {'title': '赳赳老秦', 'price': Decimal('110.00')}]>
1.2 多对多
"""
正向查询:按字段
反向查询:按表名称小写_set,其中set表示集合的意思
"""
- 正向查询(按字段)
# 查询西游记所有作者的名字
book = Book.objects.get(title='西游记')
ret = book.authors.all().values('name')
print(ret) # <QuerySet [{'name': '强子'}, {'name': '乖乖快回家'}]>
- 反向查询(按表名:book_set,按 表名称小写_set, set是集合的意思,返回queryset集合)
# 查询 强子 所有出版过的书籍名称
author_obj = Author.objects.get(name='强子')
ret = author_obj.book_set.all()
print(ret) # <QuerySet [<Book: 西游记>, <Book: 三国志>]>
1.3 一对一
"""
正向查询:按字段,返回model对象,属性取值
反向查询:按表名称小写,不用加_set;一对一查询,仅返回一个对象;返回model对象,属性取值
"""
- 正向查询(按字段)
# 查询强子的手机号
author_obj = Author.objects.get(name='强子')
ret = author_obj.author_detail.telephone
print(ret) # 111
- 反向查询(注意返回一个model对象,所以不用加 _set !!!,查到之后对象的属性取值)
# 查询手机号为111的作者名字
tel_obj = AuthorDetail.objects.get(telephone='111')
ret = tel_obj.author.name
print(ret) # 强子
1.4 related_name 覆写 FOO_set
可以通过在 ForeignKey() 和ManyToManyField的定义中设置 related_name 的值来
这篇关于Django之ORM跨表查询、join查询、聚合查询、分组查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!