mysql 行转列与列传行

目录
  • 一、行转列—case+groupby
  • 二、列转行——union

一、行转列— 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 行转列与列传行内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐