MySQL实战行转列(或称为PIVOT)实战sales的表记录了不同产品在不同月份的销售情况,进行输出

有一个sales的表,它记录了不同产品在不同月份的销售情况:

productJanuaryFebruaryMarch
Product AJanuary10
Product AFebruary20
Product BJanuary5
Product BFebruary15
Product CJanuary8
Product CFebruary12

客户需求展示为如下的样子:

productJanuaryFebruaryMarch
Product A10200
Product B5150
Product C8120

#行转列概念

行转列操作指的是将表格中一行数据转换为多列数据的操作。

SQL解决:

--创建表
CREATE TABLE sales (id INT AUTO_INCREMENT PRIMARY KEY,product VARCHAR(255),month VARCHAR(255),quantity INT
);
--插入数据
INSERT INTO sales (product, month, quantity) VALUES
('Product A', 'January', 10),
('Product A', 'February', 20),
('Product B', 'January', 5),
('Product B', 'February', 15),
('Product C', 'January', 8),
('Product C', 'February', 12);

–查询语句

SELECT product,MAX(CASE WHEN month = 'January' THEN quantity ELSE 0 END) AS January,MAX(CASE WHEN month = 'February' THEN quantity ELSE 0 END) AS February,MAX(CASE WHEN month = 'March' THEN quantity ELSE 0 END) AS March
FROM sales
GROUP BY product;

在这里插入图片描述

查询语句的解释如下:

MAX(CASE WHEN … THEN … ELSE … END): 这是一个条件聚合函数,它检查month字段的值,并在条件为真时返回相应的quantity值,否则返回0。MAX函数在这里用于确保即使有多个月份相同的记录,也只返回一个值。
AS January, AS February, AS March: 这些是列的别名,将结果列重命名为对应的月份。
FROM sales: 指定查询的表名为sales。
GROUP BY product: 按照product字段对结果进行分组,这样每个产品的销售情况都会在一行中显示。
执行上述查询后,你会得到如下结果:

productJanuaryFebruaryMarch
Product A10200
Product B5150
Product C8120

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

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

相关文章

斯坦福报告解读4:图解有趣的推理基准(中)

《人工智能指数报告》由斯坦福大学、AI指数指导委员会及业内众多大佬Raymond Perrault、Erik Brynjolfsson 、James Manyika等人员和组织合著,该报告已被公认为最权威、最具信誉人工智能数据与洞察来源之一。 2024年版《人工智能指数报告》是迄今为止最为详尽的一份…

linux下常用的终端命令

文章目录 1. MV移动文件、重命名文件1.1 移动文件:mv [选项] 源文件或目录 目标文件或目录1.2 文件重命名 2. 查找:文件,内容,统计文件2.1 find查找文件2.2 Linux查找文件内容 3. 查看当前用户4. linux修改文件所属用户和组5. 复制…

Token验证流程、代码示例、优缺点和安全策略,一文告诉你。

Token和Session都是用于身份验证和授权的机制,而且Token渐渐成为主流,有不少小伙伴对token的认识不全,这里给大家分享下。 一、什么是Token Token是一种用于身份验证和授权的令牌,通常用于在客户端和服务器之间进行安全的通信。…

SQLITE存储时间数据报警语法错误,syntax error

使用sqllite数据库,有一个时间数据current_time需要插入表中,如下 current_time time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) 不能直接将时间戳格式化为字符串并嵌入到SQL语句中,如下: sql f"INSER…

工程文档CAD转换必备!快速将 DWG 转换到 PNG ~

Aspose.CAD 是一个独立的类库,以加强Java应用程序处理和渲染CAD图纸,而不需要AutoCAD或任何其他渲染工作流程。该CAD类库允许将DWG, DWT, DWF, DWFX, IFC, PLT, DGN, OBJ, STL, IGES, CFF2文件、布局和图层高质量地转换为PDF和光栅图像格式。 Aspose AP…

gradio image 类型

3种类型,默认是 numpy.array numpy.array PIL.Image str file path. 互相转换 # 从路径到 numpy.ndarray import cv2 image_mask cv2.imread(imagePath) print(type(image_mask))# 从路径到 PIL.IMAGE from PIL import Image image_maskImage.open(imagePath) pri…

【Chrono Engine学习总结】6-创建自定义场景-6.1-3D场景获取

由于Chrono的官方教程在一些细节方面解释的并不清楚,自己做了一些尝试,做学习总结。 Chrono可以导入自定义的三维模型,所以想自己搭建一个3D仿真环境。过程中遇到了一些问题,记录与整理。 1、3D环境的创建方法 Chrono的Irrlich…

大数据模型应用领域

大数据模型的应用领域广泛,涉及多个行业和领域,其主要应用领域包括但不限于以下几个方面: 金融领域: 金融风控:大数据模型可以通过对大量数据的建模和分析,有效提高风险控制能力,识别潜在的风险…

Llama 3-V: 比GPT4-V小100倍的SOTA

大模型技术论文不断,每个月总会新增上千篇。本专栏精选论文重点解读,主题还是围绕着行业实践和工程量产。若在某个环节出现卡点,可以回到大模型必备腔调重新阅读。而最新科技(Mamba,xLSTM,KAN)则提供了大模…

只需三步,使用 KRaft 建立多节点 Kafka 集群

Apache Kafka是一个用 Java 编写的开源分布式事件和流处理平台,用于处理要求苛刻的实时数据馈送。它本质上是可扩展的,具有高吞吐量和高可用性。其设计也具有容错性,每个集群可支持数百个节点。 在本教程中,你将创建一个 Kafka 集…

ECP5701 做为PD受电端取电sink芯片,可广泛应用在带锂电的终端设备上,例如电动工具,照明灯具,音箱设备,摄影设备,筋膜枪小家电等

随着科技的发展,USB-C接口逐渐成为手机、平板电脑、小型家电等新型电子设备的主流接口,相较于过去繁杂的传统接口,USB-C不仅简化了消费者的使用体验,也降低了制造商的生产成本。特别是随着PD协议的普及,Type-C接口因其…

设计以容错:应对失败的12种关键设计思想

"Design for Failure" 这一说法在产品设计、软件开发和系统架构中并不常见,因为它通常与追求成功和可靠性的目标相悖。然而,如果我们从另一个角度来理解它,即“设计以应对失败”或“设计以容错”,那么以下是12种常见的设…

mysql数据导入navicat中,报错提示1067

MySQL导入问题: 报错1067 - Invalid default value for 字段名 由于数据库版本升级,老数据库的数据文件导出以后,在新版本的数据库上执行会报错 这种问题多是由于默认值不兼容引起的,我们可以通过修改sql_mode来解决这个问题 由…

maven 国内下载地址 配置参考

阿里云下载 速度快 https://mirrors.aliyun.com/apache/?spma2c6h.25603864.0.0.39278e42HR47Yw 配置参考 https://blog.csdn.net/qq_43604667/article/details/104695446

day17

第一题 本题可以采用快速排序的思想,适应随机数指定和三指针划分数组为三个区域的思想: 其中指针的移动细节如上题故事,如下所示: 当a区域的商都大于k时,我们要查找的k位置元素就在左区域,我们进一步在左区…

【WP|1】深入解析WordPress常用的函数、方法

WordPress 是一个广泛使用的内容管理系统(CMS),其灵活性和扩展性使其成为创建和管理网站的首选。为了充分利用 WordPress 的功能,了解其常用的函数和方法是必不可少的。本文将深入解析一些最常用和最有用的 WordPress 函数和方法&…

Java实现一个简单的计算器

当实现一个简单的计算器时,我们可以创建一个Java程序,该程序接受用户输入的两个数字和一个运算符,然后执行相应的数学运算并输出结果。下面是一个简单的Java代码示例,用于实现这样的计算器: import java.util.Scanner…

【15年成为通用MCU第一,STM32凭什么?】

微控制器(MCU)是这个快速变化世界的重要助推器和核心组成部分,也是整个数字世界应用最普遍的数字芯片之一。通用MCU市场竞争情况复杂且多样,开发者需要选择最适合的MCU产品完成创新设计。而MCU市场竞争发展的重点一定是以开发者为…

100个 Unity小游戏系列五 -Unity 抽奖游戏专题三老虎机游戏

一、演示效果 二、知识点讲解 2.1 布局 public void CreateItems(SlotsData[] slotsData){isInited false;slotsPrizeList new List<SlotsData>();for (int i 0; i < slotsData.Length; i){var item slotsData[i];slotsPrizeList.Add(item);}float bottomY -it…