My SQL 列转行操作
https://www.518cn.com 发布时间:2025-03-18 22:27 作者:网络
摘要:原表结构如下,我们可以发现,“日运输量”和“车次”是在同一张表中相互独立的两个字段,即独立的两列数据,下面,我将系统中的测试数据以及代码全部放出来,以解释列转行的
原表结构如下,我们可以发现,“日运输量”和“车次”是在同一张表中相互独立的两个字段,即独立的两列数据,下面,我将系统中的测试数据以及代码全部放出来,以解释列转行的操作方法
原表数据库查询代码:
1 SELECT 2 yzrq AS 运作日期, 3 DATE_FORMAT( yzrq, '%Y-%m' ) AS 年月, 4 rysl AS 日运输量, 5 jldw AS 计量单位, 6 cc AS 车次 7 FROM 8 uf_ysmxb
原表查询结果:
目标:车次需要按月进行统计,相当于列转行
最终需要字段:年月、月度发货量、发货量类型
第一步:我们需要单独将车次数据提取出来
SELECT yzrq, DATE_FORMAT( yzrq, '%Y-%m' ) AS 年月, cc AS 日运输量, '车次' AS 发货量类型 FROM uf_ysmxb
第二步:使用union all与其他的数据合并(到这里就已经实现了列转行的操作),注意,合并的两张表必须保证字段类型和名字一致
SELECT yzrq AS 运作日期, DATE_FORMAT( yzrq, '%Y-%m' ) AS 年月, rysl AS 日运输量, CASE jldw WHEN 34 THEN '重量' ELSE '体积' END AS 发货量类型 FROM uf_ysmxb UNION ALL SELECT yzrq, DATE_FORMAT( yzrq, '%Y-%m' ) AS 年月, cc AS 日运输量, '车次' AS 发货量类型 FROM uf_ysmxb
第三步:将数据按要求进行汇总统计
SELECT 年月, SUM(日运输量) AS 月度发货量,发货量类型 FROM ( SELECT yzrq AS 运作日期, DATE_FORMAT( yzrq, '%Y-%m' ) AS 年月, rysl AS 日运输量, CASE jldw WHEN 34 THEN '重量' ELSE '体积' END AS 发货量类型 FROM uf_ysmxb UNION ALL SELECT yzrq, DATE_FORMAT( yzrq, '%Y-%m' ) AS 年月, cc AS 日运输量, '车次' AS 发货量类型 FROM uf_ysmxb ) AS T GROUP BY 年月,发货量类型
相关文章
- 优化GreatSQL日志文件空间占用 GreatSQL对于日志文件磁盘空间占用,做了一些优化,对于binlog、...03-18
- "数据约束条件" date: 2022-11-24T21:24:31 08:00 draft: false MySQL字段约束条件 无符号, 零填充...03-18
【GreatSQL优化器-16】INDEX_SKIP_SCAN
【GreatSQL优化器-16】INDEX_SKIP_SCAN 一、INDEX_SKIP_SCAN介绍 GreatSQL 优化器的索引跳跃扫描(Index Ski...03-18- MySQL 是一个非常流行的开源关系数据库管理系统,在各种应用场景中都得到了广泛的应用。随...03-18
- 🤖 DB-GPT 是一个开源的 AI 原生数据应用程序开发框架,具有 AWEL(代理工作流表达式语...03-18
GreatSQL 8.0.32-27 GA (2025-3-10)
GreatSQL 8.0.32-27 GA (2025-3-10) 版本信息 发布时间:2025年3月10日 版本号:8.0.32-27, Revision aa66a38591...03-18- 6. MySQL 索引的数据结构(详细说明) @目录6. MySQL 索引的数据结构(详细说明)1. 为什么使用索引2...03-18
- @Override @Transactional(rollbackFor = Exception.class) public void batchInsertDeviceData(IotMsgNotifyData iotMsgNotifyDa...03-18
- 个人Qt项目总结——数据库查询断言问题 问题: 当我使用MySQL数据库的查询操作时, 如果查询...03-18
- MySQL 是一种广泛使用的关系数据库管理系统,MySQL 8 是其最新的主要版本,结合了出色的性能和...03-18
最新评论