使用 GROUP BY 进行数据库分析:以图书销售数据库为例

让我们通过一个简单但实用的例子来理解 GROUP BY 的使用。我们将以一个图书销售数据库为例。这个数据库包含两张表:一张是图书信息表 (books),另一张是销售记录表 (sales)。我们会先创建这两张表,然后插入一些数据,并展示如何使用 GROUP BY 来分析销售数据。

文章目录

    • 背景信息
    • 建表和插入数据
    • 使用 GROUP BY
      • 计算每本书的总销售量:
      • 计算每位作者的书籍总销售额:
      • 查找每本书的最大单次销售量:
    • 结论

背景信息

在数据库管理和数据分析中,GROUP BY 语句是一个强大的工具,它可以让我们根据某些列的值对数据进行分组。这对于汇总信息、生成报告或进行市场分析等任务至关重要。在本例中,我们将展示如何利用 GROUP BY 来插入、更新和分析图书销售数据。

建表和插入数据

我们的数据库设计涉及两张主要表格:图书信息表 (books) 和销售记录表 (sales)。以下是这两张表的结构和示例数据

图书信息表 (books):

  • book_id (图书ID)
  • title (图书标题)
  • author (作者)

销售记录表 (sales):

  • sale_id (销售ID)
  • book_id (图书ID)
  • sale_date (销售日期)
  • quantity (数量)
  • price (价格)

sql如下:

-- 创建书籍表
CREATE TABLE test.books (book_id INT PRIMARY KEY,title VARCHAR(100),author VARCHAR(100)
);
-- 创建销售表
CREATE TABLE test.sales (sale_id INT PRIMARY KEY,book_id INT,sale_date DATE,quantity INT,price DECIMAL(10, 2),FOREIGN KEY (book_id) REFERENCES books(book_id)
);-- 插入数据
INSERT INTO test.books (book_id, title, author) VALUES
(1, 'Data Science 101', 'Alex Johnson'),
(2, 'SQL Essentials', 'Maria Lee'),
(3, 'Advanced Analytics', 'An Nguyen');INSERT INTO test.sales (sale_id, book_id, sale_date, quantity, price) VALUES
(1, 1, '2023-06-01', 10, 29.99),
(2, 2, '2023-06-02', 5, 59.99),
(3, 3, '2023-06-03', 2, 89.99),
(4, 1, '2023-06-04', 3, 29.99),
(5, 2, '2023-06-05', 7, 59.99);

使用 GROUP BY

GROUP BY 语句允许我们按照一个或多个列来聚集数据,这对于理解数据模式非常有用。在此示例中,我们将展示如何用它来计算每本书的总销售量、每位作者的书籍总销售额以及每本书的最大单次销售量。

计算每本书的总销售量:

SELECT b.title, SUM(s.quantity) as total_quantity
FROM sales s
JOIN books b ON s.book_id = b.book_id
GROUP BY b.title;

如下:
在这里插入图片描述

计算每位作者的书籍总销售额:

select b.author,sum(s.price * s.quantity) as total
FROM test.books  b
join test.sales s  on b.book_id = s.book_id
group by b.author;

如下:
在这里插入图片描述

查找每本书的最大单次销售量:

SELECT b.title, MAX(s.quantity) as max_quantity
FROM test.sales s
JOIN test.books b ON s.book_id = b.book_id
GROUP BY b.title;

如下:
在这里插入图片描述

结论

通过上述例子,我们可以看到 GROUP BY 在数据库查询中的实用性和灵活性。无论是简单的数据汇总还是复杂的数据分析,GROUP BY 都是一个不可或缺的工具。理解并掌握它的使用,对于任何涉及数据库管理和数据分析的工作都是极其重要的。

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

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

相关文章

PHP对接企业微信

前言 最近在做项目中,要求在后台管理中有企业微信管理的相关功能。相关准备工作,需要准备好企业微信账号,添加自建应用,获得相应功能的权限,以及agentid、secre等。 参考文档: 企业微信开发文档 功能实现 因…

2、Redis变慢原因排查(下)

感觉Redis变慢了,这些可能的原因你查了没 ?(下) Redis变慢排查的上一篇【感觉Redis变慢了,这些可能的原因你查了没 ?(上)】,我们是基于Redis命令为入口,比如命令使用不得当,bigkey问题&#xf…

开发短视频矩阵实时直播需要用到哪些技术?

现在越来越多的人或公司都想开发出自己的直播网站或者直播APP,但是在技术这一块又不知道怎么下手,那么我就给大家讲一下在视频直播系统开发中要了解那些知识和技术: 在开发上需要用的技术有: 摄像头采集 音视频编解码 流媒体协议…

⭐Unity 搭建UDP客户端(01) 配合网络调试助手测试

1.接收来自服务器的消息 using System.Net; using System.Net.Sockets; using System.Text; using System.Threading; using UnityEngine;public class UDPManager:MonoBehaviour {public string recvStr; //服务器返回值public string UDPClientAddRess "192.168.2.39&q…

数字人对话系统 Linly-Talker

🔥🔥🔥数字人对话系统 Linly-Talker🔥🔥🔥 English 简体中文 欢迎大家star我的仓库 https://github.com/Kedreamix/Linly-Talker 2023.12 更新 📆 用户可以上传任意图片进行对话 介绍 Lin…

SolidWorks Simulation 有限元分析-升降架分析

问题描述:一个载重为 1800N 的升降架承受一外部水压柱筒的作用,该水压柱筒与基座上的滑块相连。 1. 打开零件。 2. 我们新建一个静应力分析的算例,如下图所示。 3. 设置材料。我们需要为模型指定模型的材料属性。点击选中模型,鼠…

Excel 分列功能

一. 需求 ⏹有一段文本,文本一共有7列。这7列文本之间的分隔符不相同 有一个空格的有多个空格的有Tab的jmw_state 和 method 之间用 & 连接 现在要求,将这段文本粘贴到Excel中,进行分列。并且需要将 jmw_state 和 method 也进行分列 也…

RabbitMQ(一)概述

1 RabbitMQ 概念 RabbitMQ 是一个消息中间件:它接受并转发消息。你可以把它当做一个快递站点,当你要发送一个包裹时,你把你的包裹放到快递站,快递员最终会把你的快递送到收件人那里,按照这种逻辑 RabbitMQ 是一个快递站…

Linux(16):认识系统服务(daemons)

什么是 daemon 与系统服务 【服务】一般的说明是【常驻在记体体中的程序,且可以提供一些系统或网络功能,那就是服务】。而服务一般的英文说法是【service】。 简单的说,系统为了某些功能必须要提供一些服务(不论是系统本身还是网络方面)&…

python基于ModBusTCP服务端的业务实现特定的client

python实现ModBusTCP协议的client是一件简单的事情,只要通过pymodbus、pyModbusTCP等模块都可以实现,本文采用pymodbus。但要基于ModBusTCP服务端的业务实现特定的client,那得看看服务端是否复杂。前面系列文章,我们学习了对服务端…

<IBM Websphere Portal>《关于IBM的Portal和WAS的说明和总结(自用笔记)》

《关于IBM的Portal和WAS的简单总结》 1 架构1.1 说明 2 常见问题2.1 LDAP链接问题2.2 启动脚本建议2.3 日志大小保留建议2.4 启动垃圾回收日志 3 日志位置 1 架构 应用服务部署架构如上: 👉192.168.66.1服务器运行的server进程有:dmgr、nodea…

SL1581降压恒压 耐压4V-30V降压5V 2A电流 外围简单,四个元器件

SL1581是一款专为降压恒压应用而设计的芯片,具有耐压4V-30V、降压5V、2A电流输出等特点,外围电路简单,仅需四个元器件。 一、芯片介绍 SL1581是一款专为降压恒压应用而设计的芯片,它采用先进的PWM控制技术,具有高效率、…

红队攻防之ActiveMQ漏洞集锦

要么拼命,要么滚回去 ActiveMQ 信息泄漏 实战 telnet x xActiveMQ Console 存在默认弱口令 实战 Apache ActiveMQ 默认开启了控制台,输入默认的账号密码admin/admin 登录成功 ActiveMQ 反序列化漏洞 实战 执行: java -jar jmet-0.1.0…

实现跨VLAN通信、以及如何配路由协议

一、如下图片: 按照拓扑图所示,为LSW1,LSW2,AR1,AR2配置IP地址,线路左侧使用小地址,右侧用大地址,交换机中使用的管理VLAN编号是99。 两个路由器的配法: 注意:首先给每两个路由器之间要在相同的…

Apache+mod_jk模块代理Tomcat容器

一、背景介绍 最近在看Tomcat运行架构原理, 正好遇到了AJP协议(Apache JServ Protocol). 顺道来研究下这个AJP协议和具体使用方法. 百度百科是这么描述AJP协议的: AJP(Apache JServ Protocol)是定向包协议。因为性能原因,使用二进制格式来传输…

西南科技大学C++程序设计实验八(多态一)

一、实验目的 1. 掌握多态性的分类; 2. 动态多态性-虚函数; 3. 理解纯虚函数的概念。 二、实验任务 1.分析以下程序,改正程序错误,写出程序输出结果,并按要求: (1)思考:输出结果中为什么类A是8个字节,类B是12个字节?分析虚函数的类的结构特点 A的字节大小为:…

导入JDBC元数据到Apache Atlas

前言 前期实现了导入MySQL元数据到Apache Atlas, 由于是初步版本,且功能参照Atlas Hive Hook,实现的不够完美 本期对功能进行改进,实现了导入多种关系型数据库元数据到Apache Atlas 数据库schema与catalog 按照SQL标准的解释,…

从 Kindle 文件中提取内容:GroupDocs.Parser V23.11

从 Kindle 文件中提取内容 2023 年 12 月 6 日 GroupDocs.Parser V23.11 增加了对 Kindle 文档格式的支持,支持从 Kindle 电子书和文档中提取文本和元数据。 GroupDocs.Parser 是一款全面的文档解析解决方案,使您能够从多种文档格式中提取文本、元数据和…

SLAM算法与工程实践——SLAM基本库的安装与使用(3):Pangolin库

SLAM算法与工程实践系列文章 下面是SLAM算法与工程实践系列文章的总链接,本人发表这个系列的文章链接均收录于此 SLAM算法与工程实践系列文章链接 下面是专栏地址: SLAM算法与工程实践系列专栏 文章目录 SLAM算法与工程实践系列文章SLAM算法与工程实践…

Linux--文件权限与shell外壳的理解

目录 一.Linux的用户与用户切换,提权 二.对文件权限的理解 1.文件权限角色的权限文件属性 2.Linux中的三种角色 3.为什么会存在所属组这个角色 4.文件属性的意义 4.1.第一个字母的意义 4.2 第2——第10个字母的意义 4.3修改文件权限的方法 三.目录权限 四…