Django Aggregation 使用指南

Django Aggregation 使用指南

在构建Django应用时,我们经常需要对数据库中的数据进行汇总或聚合操作。例如,计算某个字段的平均值、最大值或最小值。这篇文章将详细介绍如何在Django中使用聚合查询,并结合实例进行说明。

聚合查询简介

Django提供了强大的数据库查询API,可以创建、检索、更新和删除单个对象。除此之外,有时我们需要通过汇总或聚合对象集合来获取派生值。本文将介绍如何使用Django查询来生成和返回聚合值。

示例模型

我们以以下模型为例,这些模型用于跟踪一系列在线书店的库存:

from django.db import modelsclass Author(models.Model):name = models.CharField(max_length=100)age = models.IntegerField()class Publisher(models.Model):name = models.CharField(max_length=300)class Book(models.Model):name = models.CharField(max_length=300)pages = models.IntegerField()price = models.DecimalField(max_digits=10, decimal_places=2)rating = models.FloatField()authors = models.ManyToManyField(Author)publisher = models.ForeignKey(Publisher, on_delete=models.CASCADE)pubdate = models.DateField()class Store(models.Model):name = models.CharField(max_length=300)books = models.ManyToManyField(Book)

常见聚合查询示例

以下是一些常见的聚合查询示例:

  1. 计算所有书籍的总数:

    Book.objects.count()
    
  2. 计算某出版社出版的书籍总数:

    Book.objects.filter(publisher__name="BaloneyPress").count()
    
  3. 计算所有书籍的平均价格:

    from django.db.models import Avg
    Book.objects.aggregate(Avg("price"))
    
  4. 计算所有书籍的最高价格:

    from django.db.models import Max
    Book.objects.aggregate(Max("price"))
    
  5. 计算每个出版社的书籍数量:

    from django.db.models import Count
    pubs = Publisher.objects.annotate(num_books=Count("book"))
    
  6. 按书籍数量排序的前5个出版社:

    pubs = Publisher.objects.annotate(num_books=Count("book")).order_by("-num_books")[:5]
    

聚合方法详解

Django提供了两种生成聚合值的方法:

  1. 对整个查询集生成汇总值:

    from django.db.models import Avg
    Book.objects.aggregate(Avg("price"))
    

    这将计算所有书籍价格的平均值。

  2. 对查询集中的每个对象生成独立的汇总值:

    from django.db.models import Count
    books = Book.objects.annotate(num_authors=Count("authors"))
    

    这将为每本书添加一个字段,表示其作者的数量。

高级用法

  1. 结合多个聚合:

    from django.db.models import Avg, Max, Min
    Book.objects.aggregate(Avg("price"), Max("price"), Min("price"))
    
  2. 基于注释值进行过滤:

    Book.objects.annotate(num_authors=Count("authors")).filter(num_authors__gt=1)
    
  3. 注释和过滤的顺序:

    注释和过滤的顺序对查询结果有很大影响。例如:

    Publisher.objects.annotate(num_books=Count("book")).filter(book__rating__gt=3.0)
    

    与:

    Publisher.objects.filter(book__rating__gt=3.0).annotate(num_books=Count("book"))
    

    这两种查询的结果可能会有所不同,因为注释和过滤的顺序不同。

结合具体实例

我们通过以下代码实现了对Twitter数据的聚合查询:

from django.db.models import Count, Avg
from .models import TwAuthors, TwTweets# 获取每个作者的平均推文数
authors = TwAuthors.objects.annotate(avg_tweets=Avg('twtweets__id'))# 获取推文数量最多的前5个作者
top_authors = TwAuthors.objects.annotate(num_tweets=Count('twtweets')).order_by('-num_tweets')[:5]

这段代码展示了如何利用Django的聚合查询功能,获取每个作者的平均推文数,并找出推文数量最多的前5个作者。

annotateaggregate:区别

在Django中,annotateaggregate是用于生成汇总值的两种不同方法,主要区别在于它们的作用范围和结果类型。

1. annotate

  • 作用范围:对每个对象单独计算汇总值。
  • 返回结果:返回一个新的QuerySet,每个对象都会附带一个额外的属性,该属性是通过计算汇总值生成的。
  • 使用场景:当你需要对查询集中的每个对象进行汇总计算时使用。例如,你可能想知道每本书有多少个作者。
示例代码:
from django.db.models import Count# 查询每本书的作者数量
books = Book.objects.annotate(num_authors=Count('authors'))
for book in books:print(book.name, book.num_authors)

2. aggregate

  • 作用范围:对整个QuerySet进行汇总计算。
  • 返回结果:返回一个字典,键是汇总值的名称,值是计算的汇总值。
  • 使用场景:当你需要对整个查询集进行汇总计算时使用。例如,你可能想知道所有书籍的平均价格。
示例代码:
from django.db.models import Avg# 计算所有书籍的平均价格
average_price = Book.objects.aggregate(Avg('price'))
print(average_price)

结合实例

假设我们有一个包含书籍信息的数据库,并且我们想获取一些汇总信息:

使用annotate

我们想知道每个出版社出版的书籍数量:

from django.db.models import Countpublishers = Publisher.objects.annotate(num_books=Count('book'))
for publisher in publishers:print(publisher.name, publisher.num_books)

每个Publisher对象将会有一个num_books属性,表示该出版社出版的书籍数量。

使用aggregate

我们想知道所有书籍的最高价格、最低价格和平均价格:

from django.db.models import Avg, Max, Minprice_summary = Book.objects.aggregate(max_price=Max('price'),min_price=Min('price'),avg_price=Avg('price')
)
print(price_summary)

返回的price_summary是一个字典,包含了所有书籍的最高价格、最低价格和平均价格。

结论

Django的聚合查询功能非常强大,可以帮助我们高效地从数据库中提取所需的汇总数据。通过合理使用这些功能,我们可以大大简化数据统计和分析的工作。

希望这篇文章能帮助你更好地理解和使用Django的聚合查询。如果你有任何问题或建议,欢迎留言讨论。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/860116.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据库精选题(五)(事务、并行控制与恢复系统)

🌈 个人主页:十二月的猫-CSDN博客 🔥 系列专栏: 🏀数据库 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 目录 前言 概论 事务 并发控制 恢复系统 三…

游戏AI的创造思路-技术基础-机器学习(2)

本篇存在大量的公式,数学不好的孩子们要开始恶补数学了,尤其是统计学和回归方程类的内容。 小伙伴们量力而行~~~~~ 游戏呢,其实最早就是数学家、元祖程序员编写的数学游戏,一脉相承传承至今,囊括了更多的设计师、美术…

QT拖放事件之五:自定义拖放操作-拖动中的修饰符操作

1、效果 2、代码 #include "SelfButton.h" #include <QApplication>SelfButton::SelfButton(QString str ,QWidget* parent):Q

按揭和抵押的区别和联系

按揭和抵押在法律上是有所区别的&#xff1a; 抵押&#xff1a;指的是债务人&#xff08;或第三人&#xff09;将自己的动产或不动产不移交给债权人&#xff0c;作为债权的担保。债务人不履行债务时&#xff0c;债权人有权优先受偿。抵押物不转移占有&#xff0c;仍由债务人或…

JAVA系列---HttpServletRequest

Servlet 处理 HTTP 请求的流程 一般情况下&#xff0c;浏览器&#xff08;客户端&#xff09;通过 HTTP 协议来访问服务器的资源&#xff0c;Servlet 主要用来处理 HTTP 请求。核心对象有三个 Servlet&#xff1a;提供service()方法处理请求ServletRequest&#xff1a;请求信…

leetcode 560.和为k的子数组 | 叱诧风云 !前缀和 + 哈希表优化!

. - 力扣&#xff08;LeetCode&#xff09; 这道题目的解法我个人认为是非常的巧妙的&#xff0c;因为一开始我是没有想到用前缀和和哈希表来解决&#xff0c;所以今天在这里写一篇题解&#xff0c;来回顾也算是巩固一下我对于这道题目的理解。 首先我先来解释一下&#xff0…

linux中的调试工具gdb

目录 1.背景知识补充 2.使用 知识补充 1.背景知识补充 1.gcc下编译默认是release方式发布的&#xff0c;无法直接进行调试 如果要以debug方式发布&#xff0c;需要携带-g 可以使用grep查询 因为携带debug信息&#xff0c;其文件体积要大一些 2.使用 1.gdb 可执行程序 …

hibernate:hibernate初始化加载类

目录 一、SessionFactory 接口 1、初始化hibernate 2、获取SessionFactory实例 3、创建获取Session 4、关闭Session和SessionFactory 最终配置 二、Session 接口 1、get()方法和load()方法&#xff1a; 2、查询 3、保存 4、删除 5、更新 6、一个完整的DAO接口实现类 …

北邮《计算机网络》网络层笔记

文章目录 单词复习网络层前言路由算法&#xff08;构造路由表的算法&#xff09;静态路由算法自适应算法 拥塞控制QoS 服务质量&#xff08;小小的一节&#xff09;网络互联&#xff08;还是小小的一节&#xff09;Internet 单词复习 estimates boot off-line in advance refl…

【PyTorch单点知识】神经元网络模型剪枝prune模块介绍(上,非结构化剪枝)

文章目录 0. 前言1. 剪枝prune主要功能分类2. torch.nn.utils.prune中的方法介绍3. PyTorch实例3.1 BasePruningMethod3.2PruningContainer3.3 identity3.4random_unstructured3.5l1_unstructured 4. 总结 0. 前言 按照国际惯例&#xff0c;首先声明&#xff1a;本文只是我自己…

AI办公自动化:免费批量将英语电子书转成有声书

Edge-TTS是由微软推出的文本转语音Python库&#xff0c;通过微软Azure Cognitive Services转化文本为自然语音。可以作为付费文本转语音TTS服务的替代品&#xff0c;Edge-TTS支持40多种语言和300种声音&#xff0c;提供优质的语音输出 。 edge-tts支持英语、汉语、日语、韩语、…

基于Netron库的PyTorch 2.0模型可视化

【图书推荐】《从零开始大模型开发与微调&#xff1a;基于PyTorch与ChatGLM》_《从零开始大模型开发与微调:基于pytorch与chatglm》-CSDN博客 前面章节带领读者完成了基于PyTorch 2.0的MNIST模型的设计&#xff0c;并基于此完成了MNIST手写体数字的识别。此时可能有读者对我们…

C语言结构体包含结构体

C语言结构体可以包含另一个结构体&#xff1b; 下面通过一个例子看一下&#xff1b; struct Date {int day;int month;int year; };struct Person {char *name;struct Date birthday; }; ...... void CTestView::OnDraw(CDC* pDC) {CTestDoc* pDoc GetDocument();ASSERT_VAL…

备战秋招day3

碎碎念&#xff1a; 今天有个面试&#xff0c;学校这里还有实训。 今日任务&#xff1a;算法&#xff0b;mysql知识点补充 算法 24. 两两交换链表中的节点 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* List…

MySQL-索引:聚集索引、覆盖索引、组合索引、前缀索引、唯一索引

文章目录 MySQL-索引&#xff1a;聚集索引、覆盖索引、组合索引、唯一索引1、聚集索引2、覆盖索引3、组合索引4、唯一索引 MySQL-索引&#xff1a;聚集索引、覆盖索引、组合索引、唯一索引 1、聚集索引 在数据库中&#xff0c;聚集索引决定了表数据行的物理存储顺序。在InnoD…

C语言 | Leetcode C语言题解之第189题轮转数组

题目&#xff1a; 题解&#xff1a; void swap(int* a, int* b) {int t *a;*a *b, *b t; }void reverse(int* nums, int start, int end) {while (start < end) {swap(&nums[start], &nums[end]);start 1;end - 1;} }void rotate(int* nums, int numsSize, int…

国内邮件推送如何避免拦截?内容优化技巧?

国内邮件推送的平台怎么选择&#xff1f;如何提高邮件推送效果&#xff1f; 邮件营销是企业与客户沟通的重要方式&#xff0c;但在国内邮件推送过程中&#xff0c;邮件被拦截的问题屡见不鲜。为了确保邮件能够顺利送达目标用户&#xff0c;AokSend将探讨一些有效的策略&#x…

【Android】实现图片和视频混合轮播(无限循环、视频自动播放)

目录 前言一、实现效果二、具体实现1. 导入依赖2. 布局3. Banner基础配置4. Banner无限循环机制5. 轮播适配器6. 视频播放处理7. 完整源码 总结 前言 我们日常的需求基本上都是图片的轮播&#xff0c;而在一些特殊需求&#xff0c;例如用于展览的的数据大屏&#xff0c;又想展…

跟着DW学习大语言模型-什么是知识库,如何构建知识库

建立一个高效的知识库对于个人和组织来说非常重要。无论是为了个人学习和成长&#xff0c;还是为了组织的持续创新和发展&#xff0c;一个完善的知识管理系统都是不可或缺的。那么&#xff0c;如何建立一个高效的知识库呢&#xff1f; 在建立知识库之前&#xff0c;首先需要确定…

第3章 小功能大用处-事务与Lua

为了保证多条命令组合的原子性&#xff0c;Redis提供了简单的事务功能以及集成Lua脚本来解决这个问题。 首先简单介绍Redis中事务的使用方法以及它的局限性&#xff0c;之后重点介绍Lua语言的基本使用方法&#xff0c;以及如何将Redis和Lua脚本进行集成&#xff0c;最后给出Red…