学习mysql 如何行转列与列传行

 更新时间:2022年02月18日 14:26:23   作者:孙中明  
这篇文章主要介绍了mysql行转列与列传行的使用方法,帮助大家更好的理解和学习MySQL的使用,语句不难,但有一定的知识参考价值,需要的朋友可以参考一下,希望给你的学习带来帮助

一、行转列— case+group by

mysql> CREATE TABLE `TEST_TB_GRADE` (
    ->  `ID` int(10) NOT NULL AUTO_INCREMENT,
    ->  `USER_NAME` varchar(20) DEFAULT NULL,
    ->  `COURSE` varchar(20) DEFAULT NULL,
    ->  `SCORE` float DEFAULT '0',
    ->  PRIMARY KEY (`ID`)
    -> ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

插入数据:

mysql> insert into TEST_TB_GRADE(USER_NAME, COURSE, SCORE) values
    -> ("张三", "数学", 34),
    -> ("张三", "语文", 58),
    -> ("张三", "英语", 58),
    -> ("李四", "数学", 45),
    -> ("李四", "语文", 87),
    -> ("李四", "英语", 45),
    -> ("王五", "数学", 76),
    -> ("王五", "语文", 34),
    -> ("王五", "英语", 89);

查询表:

mysql> select * from test_tb_grade;
+----+-----------+--------+-------+
| ID | USER_NAME | COURSE | SCORE |
+----+-----------+--------+-------+
|  1 | 张三      | 数学   |    34 |
|  2 | 张三      | 语文   |    58 |
|  3 | 张三      | 英语   |    58 |
|  4 | 李四      | 数学   |    45 |
|  5 | 李四      | 语文   |    87 |
|  6 | 李四      | 英语   |    45 |
|  7 | 王五      | 数学   |    76 |
|  8 | 王五      | 语文   |    34 |
|  9 | 王五      | 英语   |    89 |
+----+-----------+--------+-------+

不用聚集函数和group by语句:

mysql> SELECT user_name ,
    ->   (CASE course WHEN '数学' THEN score ELSE 0 END ) 数学,
    ->   (CASE course WHEN '语文' THEN score ELSE 0 END ) 语文,
    ->   (CASE course WHEN '英语' THEN score ELSE 0 END ) 英语
    -> FROM test_tb_grade;
+-----------+--------+--------+--------+
| user_name | 数学   | 语文   | 英语   |
+-----------+--------+--------+--------+
| 张三      |     34 |      0 |      0 |
| 张三      |      0 |     58 |      0 |
| 张三      |      0 |      0 |     58 |
| 李四      |     45 |      0 |      0 |
| 李四      |      0 |     87 |      0 |
| 李四      |      0 |      0 |     45 |
| 王五      |     76 |      0 |      0 |
| 王五      |      0 |     34 |      0 |
| 王五      |      0 |      0 |     89 |
+-----------+--------+--------+--------+

用group by语句:

mysql> SELECT user_name ,
    ->   (CASE course WHEN '数学' THEN score ELSE 0 END ) 数学,
    ->   (CASE course WHEN '语文' THEN score ELSE 0 END ) 语文,
    ->   (CASE course WHEN '英语' THEN score ELSE 0 END ) 英语
    -> FROM test_tb_grade
    -> group by user_name;
+-----------+--------+--------+--------+
| user_name | 数学   | 语文   | 英语   |
+-----------+--------+--------+--------+
| 张三      |     34 |      0 |      0 |
| 李四      |     45 |      0 |      0 |
| 王五      |     76 |      0 |      0 |
+-----------+--------+--------+--------+

用group by语句和聚集函数实现行转列:

mysql> SELECT user_name ,
    ->   MAX(CASE course WHEN '数学' THEN score ELSE 0 END ) 数学,
    ->   MAX(CASE course WHEN '语文' THEN score ELSE 0 END ) 语文,
    ->   MAX(CASE course WHEN '英语' THEN score ELSE 0 END ) 英语
    -> FROM test_tb_grade
    -> group by user_name;
+-----------+--------+--------+--------+
| user_name | 数学   | 语文   | 英语   |
+-----------+--------+--------+--------+
| 张三      |     34 |     58 |     58 |
| 李四      |     45 |     87 |     45 |
| 王五      |     76 |     34 |     89 |
+-----------+--------+--------+--------+

二、列转行——union

CREATE TABLE `TEST_TB_GRADE2` (
 `ID` int(10) NOT NULL AUTO_INCREMENT,
 `USER_NAME` varchar(20) DEFAULT NULL,
 `CN_SCORE` float DEFAULT NULL,
 `MATH_SCORE` float DEFAULT NULL,
 `EN_SCORE` float DEFAULT '0',
 PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

插入数据:

insert into TEST_TB_GRADE2(USER_NAME, CN_SCORE, MATH_SCORE, EN_SCORE) values
("张三", 34, 58, 58),
("李四", 45, 87, 45),
("王五", 76, 34, 89);

查询:

mysql> select * from test_tb_grade2;
+----+-----------+----------+------------+----------+
| ID | USER_NAME | CN_SCORE | MATH_SCORE | EN_SCORE |
+----+-----------+----------+------------+----------+
|  1 | 张三      |       34 |         58 |       58 |
|  2 | 李四      |       45 |         87 |       45 |
|  3 | 王五      |       76 |         34 |       89 |
+----+-----------+----------+------------+----------+

不求并集:

mysql> select user_name, '语文' COURSE , CN_SCORE as SCORE from test_tb_grade2;
+-----------+--------+-------+
| user_name | COURSE | SCORE |
+-----------+--------+-------+
| 张三      | 语文   |    34 |
| 李四      | 语文   |    45 |
| 王五      | 语文   |    76 |
+-----------+--------+-------+

求并集:

mysql> select user_name, '语文' COURSE , CN_SCORE as SCORE from test_tb_grade2
    -> union select user_name, '数学' COURSE, MATH_SCORE as SCORE from test_tb_grade2
    -> union select user_name, '英语' COURSE, EN_SCORE as SCORE from test_tb_grade2;
+-----------+--------+-------+
| user_name | COURSE | SCORE |
+-----------+--------+-------+
| 张三      | 语文   |    34 |
| 李四      | 语文   |    45 |
| 王五      | 语文   |    76 |
| 张三      | 数学   |    58 |
| 李四      | 数学   |    87 |
| 王五      | 数学   |    34 |
| 张三      | 英语   |    58 |
| 李四      | 英语   |    45 |
| 王五      | 英语   |    89 |
+-----------+--------+-------+

order by语句:

mysql> select user_name, '语文' COURSE , CN_SCORE as SCORE from test_tb_grade2
    -> union select user_name, '数学' COURSE, MATH_SCORE as SCORE from test_tb_grade2
    -> union select user_name, '英语' COURSE, EN_SCORE as SCORE from test_tb_grade2
    -> order by user_name,COURSE;
+-----------+--------+-------+
| user_name | COURSE | SCORE |
+-----------+--------+-------+
| 张三      | 数学   |    58 |
| 张三      | 英语   |    58 |
| 张三      | 语文   |    34 |
| 李四      | 数学   |    87 |
| 李四      | 英语   |    45 |
| 李四      | 语文   |    45 |
| 王五      | 数学   |    34 |
| 王五      | 英语   |    89 |
| 王五      | 语文   |    76 |
+-----------+--------+-------+

到此这篇关于mysql 行转列与列传行的文章就介绍到这了,更多相关mysql 行转列与列传行内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql存储过程中游标的用法实例

    Mysql存储过程中游标的用法实例

    这篇文章主要介绍了Mysql存储过程中游标的用法,以商户关联数据的插入及更新为例分析了MySQL存储过程中游标的使用技巧,需要的朋友可以参考下
    2015-07-07
  • mysql 数据库基础笔记

    mysql 数据库基础笔记

    mysql 数据库基础笔记,刚开始接触mysql的朋友可以参考下
    2012-07-07
  • MySQL自动停机的问题处理实战记录

    MySQL自动停机的问题处理实战记录

    这篇文章主要给大家介绍了关于MySQL自动停机的问题处理,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-05-05
  • SQL实现LeetCode(184.系里最高薪水)

    SQL实现LeetCode(184.系里最高薪水)

    这篇文章主要介绍了SQL实现LeetCode(184.系里最高薪水),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • MySQL GTID集合运算函数总结

    MySQL GTID集合运算函数总结

    本文主要介绍了MySQL GTID集合运算函数总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-04-04
  • MySQL索引设计原则深入分析讲解

    MySQL索引设计原则深入分析讲解

    为了使索引的使用效率更高,在创建索引时,必须考虑在哪些字段上创建索引和创建什么类型的索引。索引设计不合理或者缺少索引都会对数据库和应用程序的性能造成障碍。高效的索引对于获得良好的性能非常重要。设计索引时,应该考虑相应准则
    2023-01-01
  • MySQL优化之InnoDB优化

    MySQL优化之InnoDB优化

    InnoDB是为Mysql处理巨大数据量时的最大性能设计。它的CPU效率可能是任何其它基于磁盘的关系数据库引擎所不能匹敌的。在数据量大的网站或是应用中Innodb是倍受青睐的。那么它就不需要优化了吗,答案很显然:当然不是!!!
    2017-03-03
  • mysql Innodb表空间卸载、迁移、装载的使用方法

    mysql Innodb表空间卸载、迁移、装载的使用方法

    从MySQL的Innodb特性中我们知道,Inndob的表空间有共享和独享的特点,如果是共享的。则默认会把表空间存放在一个文件中(ibdata1),当开启独享表空间参数Innodb_file_per_table时,会为每个Innodb表创建一个.ibd的文件。文章讨论在独享表空间卸载、装载、迁移Innodb表的情况
    2013-11-11
  • MySQL用作备份还原的导入和导出命令用法整理

    MySQL用作备份还原的导入和导出命令用法整理

    这篇文章主要介绍了MySQL用作备份还原的导入和导出命令用法整理,包括mysqldump的命令的使用以及load data相关命令,需要的朋友可以参考下
    2015-12-12
  • SQL中CAST()实例之转换数据类型

    SQL中CAST()实例之转换数据类型

    CAST函数用于将某种数据类型的表达式显式转换为另一种数据类型,下面这篇文章主要给大家介绍了关于SQL中CAST()实例之转换数据类型的相关资料,需要的朋友可以参考下
    2023-01-01

最新评论