Django笔记十七之group by 分组用法总结

yizhihongxing

本文首发于微信公众号:Hunter后端
原文链接:Django笔记十七之group by 分组用法总结

这篇笔记介绍 Django 里面 model 的 group by 对应的一些操作。

用到的 Model 如下:

class TestModel(models.Model):
    num = models.IntegerField()
    user_id = models.IntegerField()
    create_date = models.DateField()

我们写入几条数据:

TestModel.objects.create(num=78, user_id=1, create_date="2022-01-01")
TestModel.objects.create(num=99, user_id=1, create_date="2022-01-01")
TestModel.objects.create(num=87, user_id=1, create_date="2022-01-08")

TestModel.objects.create(num=66, user_id=2, create_date="2022-01-01")
TestModel.objects.create(num=54, user_id=2, create_date="2022-01-08")
TestModel.objects.create(num=77, user_id=2, create_date="2022-01-16")

本篇笔记的目录如下:

  1. distinct 单个字段
  2. distinct 多个字段
  3. count 字段去重后总数
  4. sum 某个字段总和
  5. group by 分组统计 count
  6. group by 分组统计 max
  7. group by 分组统计 sum
  8. group by 分组统计 count + distinct

1、distinct 单个字段

现在我们需要 user_id 这个字段进行去重处理,获取一个去重后的 user_id 的列表

使用 SQL 的话,大致如下:

select distinct user_id from blog_test;

使用 QuerySet 语句则是:

TestModel.objects.values_list("user_id", flat=True).distinct()

2、distinct 多个字段

假设需要对 user_id 和 create_date 这两个字段做去重处理,

使用 SQL 语句如下:

select distinct user_id, create_date from blog_test;

对应的 QuerySet 语句:

TestModel.objects.values("user_id").distinct()

3、count 字段去重后总数

比如我们想查看 2022-01-01 这天有多少不同 user_id 值的数据

select count(distinct user_id) from blog_test where create_date = '2022-01-01';

对应的 QuerySet 为:

TestModel.objects.filter(create_date='2022-01-01').values("user_id").distinct().count()

4、sum 某个字段总和

我们想查看 2022-01-01 这天 num 字段的数据的总和有多少:

select sum(num) from blog_test where create_date = '2022-01-01';

Django 语句:

from django.db.models import Sum

TestModel.objects.filter(create_date='2022-01-01').aggregate(sum_num=Sum('num'))

# 返回值为 
# {'sum_num': 243}

5、group by 分组统计 count

按照日期统计 user_id 的总数:

select create_date, count(user_id) from blog_test group by create_date;

Django 语句:

from django.db.models import Count

TestModel.objects.values("create_date").annotate(count=Count("user_id"))

6、group by 分组统计 max

按照日期计算每一天最大的 num 的数据:

select create_date, max(num) from blog_test group by create_date;

Django 语句:

TestModel.objects.values("create_date").annotate(max_num=Max("num"))

7、group by 分组统计 sum

按照日期计算 num 的总数:

select create_date, sum(num) from blog_test group by create_date;

Django 语句:

from django.db.models import Sum
TestModel.objects.values("create_date").annotate(sum_num=Sum("num"))

8、group by 分组统计 count + distinct

如果是对需要对 user_id 进行去重处理的统计,SQL 如下:

select create_date, count(distinct user_id) from blog_test group by create_date;

Django 语句:

TestModel.objects.values("create_date").annotate(count=Count("user_id", distinct=True))

以上就是本篇笔记全部内容,接下来会是几个深入一点的知识点的介绍,比如一个 Model 示例 save() 方法的继承和修改、主键自增和字段更新的操作。

如果想获取更多相关文章,可扫码关注阅读:
image

原文链接:https://www.cnblogs.com/hunterxiong/p/17297775.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django笔记十七之group by 分组用法总结 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • PyCharm常用配置和常用插件(小结)

    PyCharm常用配置和常用插件(小结) PyCharm是一款非常受欢迎的Python集成开发环境(IDE),支持多种操作系统,并拥有丰富的功能和插件。 常用配置 1. 解释器配置 在PyCharm中使用Python需要配置解释器,可以使用系统自带的Python解释器,也可以使用虚拟环境。 在PyCharm的Settings/Preferences中,选择P…

    python 2023年5月20日
    00
  • python通过socket实现多个连接并实现ssh功能详解

    首先我们来详细讲解如何通过 Python 的 socket 模块实现多个连接并实现 SSH 功能。 什么是 socket Socket,顾名思义就是套接字,可以理解为一种通信机制,它是计算机之间进行通信的一种约定或一种方式。在计算机网络中,Socket 起着非常重要的作用,它可以用于实现客户端和服务器之间的通信。 socket 的基本用法 在 Python …

    python 2023年5月19日
    00
  • Python爬虫实现vip电影下载的示例代码

    Python爬虫实现vip电影下载的示例代码,是指使用Python语言编写爬虫程序,模拟浏览器行为,实现获取VIP电影下载链接,从而实现免费下载VIP电影的功能。以下是该攻略的完整步骤。 确定目标网站 首先,需要确定一个目标网站,该网站提供VIP电影的下载链接,如爱奇艺、腾讯视频等。这里以腾讯视频为例。 分析网页源代码 使用浏览器开发者工具(Chrome浏览…

    python 2023年5月14日
    00
  • python中超简单的字符分割算法记录(车牌识别、仪表识别等)

    Python中超简单的字符分割算法记录 字符分割是图像处理中的一个重要问题,它的主要作用是将一张图像中的字符分割出来,以便进行后续的识别和处理。本文将介绍Python中超简单的字符分割算法,以及两个示例说明。 算法原理 Python中超简单的字符分割算法的基本思想是通过对图像进行二值化处理,然后对二值化后的图像进行连通域分析,最后根据连通域的位置和大小将字符…

    python 2023年5月14日
    00
  • python实现由数组生成对称矩阵

    生成对称矩阵是一个经常被需要的操作,Python中可以非常方便地实现对称矩阵的生成,下面给出完整的攻略: 1. 确定矩阵大小 首先需要确定生成的对称矩阵的大小,假设为 n。 2. 构造数组 根据对称矩阵的特点,只需要构造矩阵的上(下)三角矩阵即可,这里假设使用一维数组来存储上三角矩阵,数组大小为 n * (n + 1) // 2。 假设要生成的矩阵是: 1 …

    python 2023年6月6日
    00
  • python 将html转换为pdf的几种方法

    Python将HTML转换为PDF的几种方法 在本文中,我们将介绍如何使用Python将HTML转换为PDF。我们将介绍几种不同的方法,包括使用pdfkit库、使用weasyprint库和使用wkhtmltopdf工具。以下是详细的步骤和示例。 方法1:使用pdfkit库 pdfkit是一个Python库,它可以将HTML转换为PDF。以下是使用pdfkit…

    python 2023年5月15日
    00
  • Python不同目录间进行模块调用的实现方法

    当我们在编写Python项目时,通常会将不同的模块分别放置在不同的目录下,这时候就需要通过引入路径和包的方式来实现不同目录间的模块调用。下面是“Python不同目录间进行模块调用的实现方法”的完整攻略。 1. 添加模块搜索路径 Python会在sys.path变量中存储模块搜索路径,我们可以通过修改sys.path来添加我们自定义的模块搜索路径,以实现调用不…

    python 2023年6月3日
    00
  • PYTHON实现SIGN签名的过程解析

    PYTHON实现SIGN签名的过程解析 什么是SIGN签名? SIGN签名是一种加密方式,它可以保证数据的完整性和安全性。在网络传输过程中,数据容易受到篡改或伪造,SIGN签名可以对数据进行加密,加密后的数据在传输过程中不能被篡改或伪造。 SIGN签名的过程 客户端请求签名参数,并将请求参数按照字典升序排序后,按照key1=value1&key2=v…

    python 2023年6月3日
    00
合作推广
合作推广
分享本页
返回顶部