Django聚合查询和分组查询

聚合查询

聚合查询是对查询结果集进行某种特定的操作或者计算出某个值,例如对结果集求和、平均值、最大值、最小值等操作。在 Django 中,聚合查询的方法是使用 aggregate() 函数。

(1) 获得所有人的平均年龄

from django.db.models import Avg
from yourapp.models import Person

result = Person.objects.aggregate(avg_age=Avg('age'))
print(result['avg_age'])

(2) 查询男性和女性的人数及平均年龄

from django.db.models import Count, Avg
from yourapp.models import Person

result = Person.objects.values('gender').annotate(num_person=Count('id'), avg_age=Avg('age'))
for r in result:
    print(r['gender'], r['num_person'], r['avg_age'])

分组查询

分组查询是将查询结果按照某几列进行分组,并计算分组内的统计值,例如对某一列进行统计数值,并将结果按照指定列分组显示。在 Django 中,分组查询的方法是使用 values() 函数和 annotate() 函数。

(1) 查询男性和女性的人数

from django.db.models import Count
from yourapp.models import Person

result = Person.objects.values('gender').annotate(num_person=Count('id'))
for r in result:
    print(r['gender'], r['num_person'])

(2) 查询每个部门的人数

from django.db.models import Count
from yourapp.models import Person

result = Person.objects.values('department').annotate(num_person=Count('id'))
for r in result:
    print(r['department'], r['num_person'])

(3) 查询每个部门的平均年龄

from django.db.models import Avg
from yourapp.models import Person

result = Person.objects.values('department').annotate(avg_age=Avg('age'))
for r in result:
    print(r['department'], r['avg_age'])

此文章发布者为:Python技术站作者[metahuber],转载请注明出处:http://pythonjishu.com/django-group-search/

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023年 3月 12日 下午9:43
下一篇 2023年 3月 12日 下午9:44

相关推荐

  • 详解Django CBV基类View源码解析

    什么是Django CBV? Django CBV,即Django的基于类的视图(Class-based views),是Django框架中的一个重要组件之一。相比于FBV(函数视图),CBV更加面向对象,使得代码更加可复用、可维护、可扩展。CBV支持多种HTTP请求方法,如GET、POST、PUT、DELETE等。 Django CBV中的基类View D…

    Django 2023年 3月 12日
    00
  • Django中的缓存机制及其实现方法

    什么是缓存? 简单来说,缓存就是将计算结果或数据存储到内存或其他更快存储介质中,以便后续请求快速访问,提高性能和响应速度。类似的概念常被用于Web框架和数据库中,用以优化性能和响应速度。 Django中的缓存机制 Django提供了多个缓存选择和多种缓存技术,包括内存缓存,数据库缓存,文件系统缓存等。Django默认使用的是基于内存的缓存,在Django的s…

    Django 2023年 3月 13日
    00
  • Django Auth应用定义登录视图的方式

    Django Auth应用是Django自带的身份认证应用程序,提供了默认的用户注册、登录、注销、修改密码等功能。在实际项目中,我们需要根据业务需求定义自己的登录视图,本文将详细介绍Django Auth应用定义登录视图的完整攻略,包括如何创建自定义登录模板、定义登录表单、定义登录视图以及实现重定向功能。 创建自定义登录模板 我们首先需要创建自定义的登录模板…

    Django 2023年 3月 13日
    00
  • Django项目部署流程与Nginx安装配置

    安装Nginx 在Ubuntu系统中,可以通过以下命令安装Nginx: sudo apt-get update sudo apt-get install nginx 配置静态文件访问 在Django项目的settings.py文件中,加入以下代码: STATIC_URL = '/static/' STATIC_ROOT = os.path…

    Django 2023年 3月 13日
    00
  • Django Form表单自定义验证规则

    Django Form表单自定义验证规则是开发中常用的功能之一,本文将详细介绍如何自定义验证规则,包括如何定义验证方法并将其添加到表单中,以及如何在视图中使用表单进行数据验证。 定义验证方法 要自定义表单验证规则,首先需要定义一个验证方法。这个方法应该以表单字段的值为参数,并返回布尔值,指示该值是否有效。例如: def validate_even(value…

    Django 2023年 3月 12日
    00
  • 详解Django用户认证系统权限管理

    Django是一个强大的Web框架,内置了完整的用户认证系统和权限管理功能,可以方便地实现用户身份验证和授权管理。 本文将详细介绍Django用户认证系统和权限管理的完整攻略,包括用户登录、注册、密码重置、用户权限和角色管理等方面的内容,并提供代码示例。 用户认证系统 用户登录 Django内置了用户登录视图和模板,可以方便地实现用户登录功能。以下是一个简单…

    Django 2023年 3月 13日
    00
  • 详解Django HTML表单实现用户注册

    本文将详细介绍 Django HTML表单实现用户注册的完整方法。 创建Django项目和应用程序 首先,我们需要在Django中创建一个项目并添加一个应用程序。在终端中执行以下命令: $ django-admin startproject myproject $ cd myproject $ python manage.py startapp myapp …

    Django 2023年 3月 12日
    00
  • Django Cache缓存系统详解

    Django是一个用于Web开发的高级Python框架,拥有强大的缓存系统,以提高Web应用程序的速度和效率,减轻服务器的负担。 缓存是将计算结果存储在一个易于访问的地方,以便后续访问可以快速获得结果,从而避免了对你的服务器资源的频繁请求,缓存的好处是提高了Web应用程序的性能,让用户能够更快地获得响应结果,减少了数据访问延迟,提高了应用程序的可用性。 Dj…

    Django 2023年 3月 12日
    00
  • Django信号机制执行过程及其应用

    Django信号机制是它框架中的核心部分,用于执行某些操作时触发某些事件。例如,在保存一个模型实例时,我们可以使用信号来在保存前或保存后执行某些操作。 Django信号机制的基本执行流程如下: 为信号定义一个接收器函数(或回调函数),该函数将在信号被发送时执行。 将接收器函数与信号关联。 当信号被发送时,所有与之关联的接收器函数都将被执行。 下面是一个简单的…

    Django 2023年 3月 13日
    00
  • 启动Django项目

    Django是一个高效、灵活、模块化的Python web框架,用于快速开发Web应用程序。Django的核心包括模型、视图和模板,它们可以帮助开发人员快速构建功能强大的Web应用程序,并提供一种易于使用的API来连接不同的组件。 在这篇文章中,我们将学习如何启动Django项目。下面是详细的步骤: 首先,确保你安装了Python。 你需要安装Python才…

    Django 2023年 3月 12日
    00