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

(0)

相关推荐

  • MySQL存储过程中使用动态行转列

    本文介绍的实例成功的实现了动态行转列.下面我以一个简单的数据库为例子,说明一下. 数据表结构 这里我用一个比较简单的例子来说明,也是行转列的经典例子,就是学生的成绩 三张表:学生表.课程表.成绩表 学生表 就简单一点,学生学号.学生姓名两个字段 CREATE TABLE `student` ( `stuid` VARCHAR(16) NOT NULL COMMENT '学号', `stunm` VARCHAR(20) NOT NULL COMMENT '学生姓名', PRIMARY KEY (`

  • mysql 行转列和列转行实例详解

    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', PRIM

  • MySQL 中行转列的方法

    MySQL行转列操作 所谓的行转列操作,就是将一个表的行信息转化为列信息,说着可能比较笼统,这里先举个例子,如下: +----+-----------+--------+-------+ | ID | USER_NAME | COURSE | SCORE | +----+-----------+--------+-------+ | | 张三 | 数学 | | | | 张三 | 语文 | | | | 张三 | 英语 | | | | 李四 | 数学 | | | | 李四 | 语文 | | | |

  • MySQL 行转列详情

    目录 一.行转列SQL写法 二.如果领导@你,让你在结果集中加上总数列呢? 三.领导又双叒叕@你改需求 四.结束语 附录:创建表结构&测试数据SQL   MySQL行转列,对经常处理数据的同学们来说,一定是不陌生的,甚至是印象深刻,因为它大概率困扰过你,让你为之一愣~ 但当你看到本文后,这个问题就不在是问题,及时收藏,以后谁再问你这个问题,直接甩他脸上,粘贴即用. 首先,我们看一下咱们的测试表数据和预期查询的结果: mysql> SELECT * FROM t_gaokao_score; +

  • MySQL中将一列以逗号分隔的值行转列的实现

    前言 有时会遇到没有遵守第一范式设计模式的业务表.即一列中存储了多个属性值.如下表 pk value 1 ET,AT 2 AT,BT 3 AT,DT 4 DT,CT,AT 一般有这两种常见需求(测试数据见文末) 1.得到所有的不重复的值,如 value AT BT CT DT ET SQL如下: select distinct(substring_index(substring_index(a.col,',',b.help_topic_id+1),',',-1)) from (select gr

  • 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,     ->  `SC

  • 学习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,     ->  `SC

  • MySQL中列转行和行转列总结解决思路

    目录 引言 列转行 行转列 总结 引言 在学习sql中遇到了列转行和行转列的题目,这里总结一下如何在对应的情景下解决不同的题目: 列转行 创建一个表stu_score_01: SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for stu_score_01 -- ---------------------------- DROP TABLE IF E

  • SQL行转列和列转行代码详解

    行列互转,是一个经常遇到的需求.实现的方法,有case when方式和2005之后的内置pivot和unpivot方法来实现. 在读了技术内幕那一节后,虽说这些解决方案早就用过了,却没有系统性的认识和总结过.为了加深认识,再总结一次. 行列互转,可以分为静态互转,即事先就知道要处理多少行(列);动态互转,事先不知道处理多少行(列). --创建测试环境 USE tempdb; GO IF OBJECT_ID('dbo.Orders') IS NOT NULL DROP TABLE dbo.Orde

  • pandas.DataFrame的pivot()和unstack()实现行转列

    示例:有如下表需要进行行转列: 代码如下: # -*- coding:utf-8 -*- import pandas as pd import MySQLdb from warnings import filterwarnings # 由于create table if not exists总会抛出warning,因此使用filterwarnings消除 filterwarnings('ignore', category = MySQLdb.Warning) from sqlalchemy im

  • postgresql高级应用之行转列&汇总求和的实现思路

    前言 节前公司业务方需要做一個統計報表,这个报表用于统计当月估计几个明星品的销售情况,而我们的数据是按行存储的就是日期|产品|渠道|销售额这样,说是也奇了怪了,我们买的报(guan)表(yuan)系(la)统(ji) 竟然不能容易地实现...,于是我看了看,然后想了想,发现是可以通过sql算出这样一个报表(多亏了postgresql的高阶函数

随机推荐