MySQL DML操作--------实现pivot行转列功能最佳实战
发表于:2024-11-20 作者:千家信息网编辑
千家信息网最后更新 2024年11月20日,1. 背景 * 由于MySQL 不支持类型Oracle与SQL Server的pivot功能进行行列转换。2. 表与数据mysql> select * from t_temp;+---------+-
千家信息网最后更新 2024年11月20日MySQL DML操作--------实现pivot行转列功能最佳实战
1. 背景
* 由于MySQL 不支持类型Oracle与SQL Server的pivot功能进行行列转换。
2. 表与数据
mysql> select * from t_temp;+---------+-----------+------------+| year | season | orderCount |+---------+-----------+------------+| 2010年 | 一季度 | 100 || 2010年 | 二季度 | 200 || 2010年 | 三季度 | 300 || 2010年 | 四季度 | 400 || 2011年 | 一季度 | 150 || 2011年 | 二季度 | 300 || 2011年 | 三季度 | 450 || 2011年 | 四季度 | 600 |+---------+-----------+------------+8 rows in set (0.00 sec)
3. 通过子查询与case when判断实现
mysql> select year, sum(orderCount1) '第一季度', -> sum(orderCount2) '第二季度', -> sum(orderCount3) '第三季度', -> sum(orderCount4) '第四季度' -> from -> ( -> select year, -> case when season = '一季度' then -> orderCount -> end orderCount1, -> case when season = '二季度' then -> orderCount -> end orderCount2, -> case when season = '三季度' then -> orderCount -> end orderCount3, -> case when season = '四季度' then -> orderCount -> end orderCount4 -> from t_temp -> ) t -> group by year;+---------+--------------+--------------+--------------+--------------+| year | 第一季度 | 第二季度 | 第三季度 | 第四季度 |+---------+--------------+--------------+--------------+--------------+| 2010年 | 100 | 200 | 300 | 400 || 2011年 | 150 | 300 | 450 | 600 |+---------+--------------+--------------+--------------+--------------+2 rows in set (0.00 sec)
4. 通过IF聚合函数实现
mysql> SELECT year, -> SUM(IF(season = '一季度', orderCount, null)) AS '第一季度', -> SUM(IF(season = '二季度', orderCount, null)) AS '第二季度', -> SUM(IF(season = '三季度', orderCount, null)) AS '第三季度', -> SUM(IF(season = '四季度', orderCount, null)) AS '第四季度' -> FROM t_temp -> GROUP BY year;+---------+--------------+--------------+--------------+--------------+| year | 第一季度 | 第二季度 | 第三季度 | 第四季度 |+---------+--------------+--------------+--------------+--------------+| 2010年 | 100 | 200 | 300 | 400 || 2011年 | 150 | 300 | 450 | 600 |+---------+--------------+--------------+--------------+--------------+2 rows in set (0.00 sec)
5. 总结
以需求驱动技术,技术本身没有优略之分,只有业务之分。
二季度
四季
技术
功能
业务
函数
只有
数据
类型
背景
行列
需求
支持
查询
驱动
实战
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
金乡软件开发
status 数据库
组织网络安全企业展
olap适合用什么数据库
服务器Z800 装win10
url转发服务器防护
潮州软件开发公司怎么选
vb 在数据库保存代码
厦门湖里小程序软件开发
网络安全项目建设进度计划书
医院管理系统mysql数据库
网站上传数据库吗
网络安全工作水平有待加强
腾讯云linux服务器亚马逊
软件开发是核心技术吗
银行管理软件开发
数据库date类型如何赋值
沈阳dell服务器
网络安全风险分析
车载软件开发程序
云服务器tt393
佛山数字软件开发优化价格
陕西时代网络技术服务工程
计算机网络技术属于啥一级门类
河南海宽计算机软件开发
张家口市网络安全宣传
西奥acd2mr服务器呼梯
无线网络安全检测标准
类似菜鸟驿站软件开发
农业农村网络安全宣传