MySQL中实现行列转换的示例

在 MySQL 中进行行列转换(即,将某些列转换为行或将某些行转换为列)通常涉及使用条件逻辑和聚合函数。虽然 MySQL 没有像 Oracle/SQL Server 中的 PIVOT 和 UNPIVOT 那样的直接功能,但你可以通过结合 CASE 语句、UNION 或 UNION ALL、以及 GROUP BY 等来实现这些转换。

1、行转列的操作

在 MySQL 中,并没有内置的 PIVOT 函数,如 Oracle/SQL Server 中那样。但是,你可以使用条件聚合或 CASE 语句来模拟 PIVOT 操作。

以下是一个简单的示例,说明如何在 MySQL 中模拟 PIVOT。

假设你有一个名为 t_sales 的表,它记录了销售数据,结构如下:

CREATE TABLE t_sales (  id int primary key auto_increment,col_year INT,  product VARCHAR(255),  amount DECIMAL(10, 2)  
);  INSERT INTO t_sales (col_year, product, amount) VALUES  
(2020, 'A001', 100),  
(2020, 'B001', 120),  
(2021, 'A001', 150),  
(2021, 'B001', 150),
(2022, 'A001', 260),  
(2022, 'B001', 240),
(2023, 'B001', 330),
(2024, 'A001', 440);(root@localhost:mysql.sock)[superdb 10:49:26]>select * from t_sales;
+----+----------+---------+--------+
| id | col_year | product | amount |
+----+----------+---------+--------+
|  1 |     2020 | A001    | 100.00 |
|  2 |     2020 | B001    | 120.00 |
|  3 |     2021 | A001    | 150.00 |
|  4 |     2021 | B001    | 150.00 |
|  5 |     2022 | A001    | 260.00 |
|  6 |     2022 | B001    | 240.00 |
|  7 |     2023 | B001    | 330.00 |
|  8 |     2024 | A001    | 440.00 |
+----+----------+---------+--------+
8 rows in set (0.00 sec)

现在,假设你想要将产品列 (product) 转换为列标题,并为每个年份和产品显示销售额。在 Oracle/SQL Server 中,你可以使用 PIVOT 来实现这一点。但在 MySQL 中,你可以这样做:

SELECT   col_year,  SUM(CASE WHEN product = 'A001' THEN amount ELSE 0 END) AS 'A_product',  SUM(CASE WHEN product = 'B001' THEN amount ELSE 0 END) AS 'B_product'  
FROM t_sales
GROUP BY col_year;(root@localhost:mysql.sock)[superdb 10:50:29]>SELECT   ->     col_year,  ->     SUM(CASE WHEN product = 'A001' THEN amount ELSE 0 END) AS 'A_product',  ->     SUM(CASE WHEN product = 'B001' THEN amount ELSE 0 END) AS 'B_product'  -> FROM t_sales-> GROUP BY col_year;-- 这将返回以下结果
+----------+-----------+-----------+
| col_year | A_product | B_product |
+----------+-----------+-----------+
|     2020 |    100.00 |    120.00 |
|     2021 |    150.00 |    150.00 |
|     2022 |    260.00 |    240.00 |
|     2023 |      0.00 |    330.00 |
|     2024 |    440.00 |      0.00 |
+----------+-----------+-----------+
5 rows in set (0.00 sec)

这就是在 MySQL 中模拟 PIVOT 的方法。对于更复杂的转换或更多的产品,你可能需要扩展 CASE 语句来包含更多的条件。

2、列转行的操作

在 MySQL 中,没有直接的 UNPIVOT 操作,因为 UNPIVOT 是 SQL Server 和 Oracle 等数据库系统中的功能,用于将多列转换为多行。但是,你可以使用 MySQL 的查询技巧来模拟 UNPIVOT 操作。

假设你有一个类似 PIVOT 后的结果集,并且你想要将其转换回原始的多行格式,你可以使用 UNION ALL 或 UNION(取决于是否要消除重复行)来模拟 UNPIVOT。

以下是一个示例,说明如何在 MySQL 中模拟 UNPIVOT 操作:

假设你有一个 t_pivoted_sales 表,它是通过 PIVOT(或上述的 MySQL 模拟方法)得到的:

CREATE TABLE t_pivoted_sales (  id int primary key auto_increment,col_year INT,  A_product DECIMAL(18, 2),  B_product DECIMAL(18, 2)  
);  INSERT INTO t_pivoted_sales (col_year, A_product, B_product) VALUES  
(2020, 100.00, 120.0),  
(2021, 150.00, 150.00),
(2022, 260.00, 240.00),
(2023, 0.00, 330.00),
(2024, 440.00, 0.00);(root@localhost:mysql.sock)[superdb 11:02:54]>select * from t_pivoted_sales;
+----+----------+-----------+-----------+
| id | col_year | A_product | B_product |
+----+----------+-----------+-----------+
|  1 |     2020 |    100.00 |    120.00 |
|  2 |     2021 |    150.00 |    150.00 |
|  3 |     2022 |    260.00 |    240.00 |
|  4 |     2023 |      0.00 |    330.00 |
|  5 |     2024 |    440.00 |      0.00 |
+----+----------+-----------+-----------+
5 rows in set (0.00 sec)

现在,你想要将 A_product 和 B_product 列转换回多行格式,其中有一个额外的列product来表示产品(A_product 或 B_product)。你可以使用以下查询来模拟 UNPIVOT:

SELECT col_year, 'A_product' AS product, A_product AS amount FROM t_pivoted_sales
union all
SELECT col_year, 'B_product' AS product, B_product AS amount FROM t_pivoted_sales
order by col_year;

这将返回以下结果
在这里插入图片描述

这就是在 MySQL 中模拟 UNPIVOT 操作的方法。通过为每个你想要“unpivot”的列创建一个 SELECT 语句,并使用 UNION ALL 将它们组合在一起,你可以得到期望的多行格式结果。

**** 欢迎点赞收藏及评论交流,万分感谢!****

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

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

相关文章

汽车信息安全硬件讨论:SE vs HSM

目录 1.什么是Secure Element 2.芯片内置HSM和SE 3.未来HSM的发展 现在的智能网联汽车看起来像是一个连接万物的智能移动终端,它不仅可以与OEM云服务器通信接收OTA推送,还可以与手机蓝牙、Wifi交互完成远程汽车解锁、座舱内环境设置等等,借…

echarts dataZoom用按钮代替鼠标滚轮实现同样效果

2024.06.19今天我学习了echarts dataZoom如何用按钮来控制放大缩小的功能, 效果如下: 通过控制按钮来实现图表放大缩小数据的效果。 步骤如下: 一、写缩放按钮,以及图表数据。 二、设置初始位置的变量,我这边是七个…

Github链接加速

链接1: github

爬虫学习。。。。

爬虫的概念: 爬虫是一种自动化信息采集程序或脚本,用于从互联网上抓取信息。 它通过模拟浏览器请求站点的行为,获取资源后分析并提取有用数据,这些数据可以是HTML代码、JSON数据或二进制数据(如图片、视频&#xff09…

【类型转换】C++中char、char*、int、string相互转换函数及string转不同进制数函数

参考资料:cplusplus官方资料strtol 函数用法 总结: 1、这些在做编程题处理输入数据时常用,需要牢记。

vue 弹出消息框

为了体现更好的交互性,免不了会用到消息弹出功能,于是antd vue提供了很多可以使用的消息控件,比如Modal,message,Popover这些控件。下面就我用过的进行总结。 1. Modal.method() 方法: Modal.warning({title: 提示,content: 未完…

打造智能家居:用ESP32轻松实现无线控制与环境监测

ESP32是一款集成了Wi-Fi和蓝牙功能的微控制器,广泛应用于物联网项目。它由Espressif Systems公司开发,具有强大的处理能力和丰富的外设接口。下面我们将详细介绍ESP32的基础功能和引脚功能,并通过具体的实例项目展示其应用。 主要功能 双核处…

XSS+CSRF组合拳

目录 简介 如何进行实战 进入后台创建一个新用户进行接口分析 构造注入代码 寻找XSS漏洞并注入 小结 简介 (案例中将使用cms靶场来进行演示) 在实战中CSRF利用条件十分苛刻,因为我们需要让受害者点击我们的恶意请求不是一件容易的事情…

商业银行数据资产管理体系建设的实践与展望

随着数字经济的快速发展,数据已成为商业银行的核心资产。商业银行在数字化转型过程中,面临如何有效管理和利用海量数据资产的挑战。本文基于《商业银行数据资产管理体系建设实践报告》,探讨浦发银行、IBM和中国信息通信研究院在数据资产管理体…

DVWA - Brute Force

DVWA - Brute Force 等级:low ​ 直接上bp弱口令爆破,设置变量,攻击类型最后一个,payload为用户名、密码简单列表 ​ 直接run,长度排序下,不一样的就是正确的用户名和密码 ​ 另解: 看一下…

NSSCTF-Web题目8

目录 [LitCTF 2023]Http pro max plus 1、题目 2、知识点 3、思路 [NSSCTF 2022 Spring Recruit]babyphp 1、题目 2、知识点 3、思路 [LitCTF 2023]Http pro max plus 1、题目 2、知识点 http数据包头部字段 3、思路 打开题目 第一想法就是加上X-forwarded-for字段 …

一分钟搭建新生录取查询系统

小伙伴们,新学期就要开始了,招生老师们,你们准备好迎接新生了吗?我给老师们分享一个超级实用的小技巧——如何用快速搭建一个新生录取查询系统! 准备好录取名单的电子表格,记得包含“姓名”和“手机号”这样…

【LeetCode 5.】 最长回文子串

一道题能否使用动态规划就在于判断最优结构是否是通过最优子结构推导得到?如果显然具备这个特性,那么就应该朝动态规划思考。如果令dp[i][j]表示串s[i:j1]是否是回文子串,那么判断dp[i][j] 是否是回文子串,相当于判断s[i] 与 s[j]…

AI企业盈利与成本问题

一、AI技术成本超预期,初创公司财务压力凸显 近期,AI领域的一些初创公司正面临财务压力,外媒记者亚伦费尔南德斯认为这可能标志着AI热潮时期即将结束。自3月中旬以来,包括Inflection AI、Stability AI和Anthropic在内的几家公司均…

函数指针的使用是否必须需要加符号?

在C或C等编程语言中,函数指针是一种特殊的指针类型,它用来指向一个函数。使用函数指针时,通常不需要在函数名后面加 & 符号。函数指针的声明和使用通常遵循以下规则: 1.声明函数指针:声明一个函数指针时&#xff…

Python中的TXT文档处理:导出与读取

Python中的TXT文档处理:导出与读取 在数据处理和分析中,文本文件(尤其是TXT和CSV格式)经常被用作数据交换的标准格式。本文将详细探讨如何在Python中处理TXT文件,包括如何导出和读取TXT文档,以及与CSV格式…

可视化大屏:选了浅色系,结果悲剧了

某些时候,有些客户不听劝告,感觉深色系大屏过于压抑,就让用浅色系,结果浅色系投到大屏上,直接亮瞎了。 选择浅色系的可视化大屏可能会存在以下几个问题: 视觉疲劳: 浅色系的颜色相对较亮&…

MySQL的引擎InnoDB和MyISAM有什么区别

一、典型回答 InnoDB和MyISAM是MySQL中比较常用的两个执行引擎,MySQL在5.5之前版本默认存储引擎是MyISAM,5.5之后版本默认存储引擎是InnoDB,MyISAM适合查询以及插入为主的应用,InnoDB适合频繁修改以及涉及安全性较高的应用。 如果…

极限编程里最容易被忽略的实践

在前面的一篇文章里面我和大家聊过了极限编程的重要性,今天想和大家聊聊极限编程里面最简单但也往往最容易被忽略的实践——编码规范。 说到编码规范,每一个开发人员都非常熟悉,每一个团队也都有自己的编码规范。但实际的执行情况如何呢&…

深圳信用贷款之路:申请了10次都被拒!这三步帮你逆袭银行贷款!

贷款客户最头疼的就是明明查询了一堆资料,贷款还是办不下来!尤其是那些负债累累的,急需资金还月供和本金的朋友们,不是在贷款就是在贷款的路上,一个月申请了10次都被拒!去了好几家贷款机构,费用…