Django之ORM跨表查询、join查询、聚合查询、分组查询

2024-02-19 07:58

本文主要是介绍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查询、聚合查询、分组查询的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/724014

相关文章

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组

Django中使用SMTP实现邮件发送功能

《Django中使用SMTP实现邮件发送功能》在Django中使用SMTP发送邮件是一个常见的需求,通常用于发送用户注册确认邮件、密码重置邮件等,下面我们来看看如何在Django中配置S... 目录1. 配置 Django 项目以使用 SMTP2. 创建 Django 应用3. 添加应用到项目设置4. 创建

Redis KEYS查询大批量数据替代方案

《RedisKEYS查询大批量数据替代方案》在使用Redis时,KEYS命令虽然简单直接,但其全表扫描的特性在处理大规模数据时会导致性能问题,甚至可能阻塞Redis服务,本文将介绍SCAN命令、有序... 目录前言KEYS命令问题背景替代方案1.使用 SCAN 命令2. 使用有序集合(Sorted Set)

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来