mysql行列转换
来源:互联网 发布:星际战甲奶妈回蓝算法 编辑:程序博客网 时间:2024/05/17 23:39
一;列转行
1:创建表
CREATE TABLE `score` ( `name` varchar(10) DEFAULT NULL, `course` varchar(10) DEFAULT NULL, `score` int(11) DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8
--->>>插入数据
INSERT INTO score(NAME, COURSE, SCORE) VALUES
("张三", "语文", 88),
("张三", "数学", 92),
("张三", "物理", 93),
("李四", "语文", 79),
("李四", "数学", 99),
("李四", "物理", 94)
查询 SELECT * FROM score
name course score
------ ------ --------
张三 语文 88
张三 数学 92
张三 物理 93
李四 语文 79
李四 数学 99
李四 物理 94
2:转换语句
CREATE VIEW aaa AS
SELECT NAME,
SUM(CASE WHEN course = '语文' THEN score ELSE 0 END) AS "语文",
SUM(CASE WHEN course = '数学' THEN score ELSE 0 END) AS "数学",
SUM(CASE WHEN course = '物理' THEN score ELSE 0 END) AS "物理"
FROM score GROUP BY NAME;
select * from aaa;
NAME 语文 数学 物理
------ ------ ------ --------
张三 88 92 93
李四 79 99 94
二:行转列(使用上面的aaa视图横表)
1.转换语句
SELECT NAME,'语文' course,语文 soure FROM aaa
UNION SELECT NAME,'数学' course,数学 soure FROM aaa
UNION SELECT NAME,'物理' course,物理 soure FROM aaa
ORDER BY NAME,course;
2.结果
name course soure
------ ------ --------
张三 数学 92
张三 物理 93
张三 语文 88
李四 数学 99
李四 物理 94
李四 语文 79
三:拓展(GROUP_CONCAT(param)和group连用)
1语句:
SELECT NAME ,GROUP_CONCAT(course) courses ,GROUP_CONCAT(score) scores
FROM score GROUP BY NAME;
2结果:
me courses scores
------ ------------------- ----------
张三 语文,数学,物理 88,92,93
李四 语文,数学,物理 79,99,94
- Mysql行列转换
- mysql行列转换
- Mysql 行列转换
- mysql行列转换示例
- mysql 行列转换
- mysql 行列转换方式
- MySQL的行列转换
- Mysql行列转换
- MySQL 行列转换
- Mysql-行列转换
- mysql行列转换
- mysql行列转换
- mysql的行列转换
- mysql行列转换
- mysql行列转换
- mysql行列转换方法总结
- mysql行列转换方法总结
- mysql行列转换方法总结
- np.ravel()和np.flatten()
- Android studio 自带模拟器在联想thinkpad E470c 笔记本中无法打开问题
- 七层结构模型
- 【类反射】类反射原理和获取Class对象的三种方式
- Eclipse 新建Servlet出错问题
- mysql行列转换
- Code+12月月赛比赛过程记录(个人向)
- Spark External Data Source API
- 【Android开发】id="@+id/xxx"与id="@id/xxx"的区别
- 【BigHereo 53】---Redis遇到的问题---雪崩,击穿,穿透
- unity编辑器扩展篇-视图拓展基础
- 解决mac下yarn安装vue-socket.io / node-gyp 出现uws且卡住的问题
- 依托先进优化理念提升网站运营水平
- Putty登录阿里云CentOS时出现错误:Disconnected:No supported authentication methods available