MySQL -- 行转列 -- GROUP_CONCAT -- MAX(CASE WHEN THEN)

Posted limeOracle

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL -- 行转列 -- GROUP_CONCAT -- MAX(CASE WHEN THEN)相关的知识,希望对你有一定的参考价值。

列转行:利用max(case when then)

 

SELECT
    `name`,
    MAX(
        CASE 
        WHEN  course=\'语文\' THEN
            score
        END
    ) AS 语文,
    MAX(
        CASE 
        WHEN course=\'数学\' THEN
            score
        END
    ) AS 数学, 
    MAX(
        CASE 
        WHEN course=\'英语\' THEN
            score
        END
    ) AS 英语
FROM
    student
GROUP BY `name`
;

 

合并字段显示:利用group_cancat(course,”:”,”score”)

SELECT
    `name`,
    GROUP_CONCAT(course, ":", score) AS 成绩
FROM
    student
GROUP BY
    `name`;

 -- -- -- -- -- -- -- --- - -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --- - -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --- - -- -- -- -- -- -- -- -- -- -- -- -- -

-- 合并字段显示 : 去重、排序
SELECT rid,GROUP_CONCAT(DISTINCT gid ORDER BY gid)
FROM gt_lighting.res_lights
GROUP BY rid;

 

-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 

多来点面试题:

计算各班级及格人数:

    SELECT class,SUM(CASE WHEN score >= 60 THEN 1 END) AS \'及格\',SUM(CASE WHEN score < 60 THEN 1 END) AS \'不及格\'
    FROM gradeTable
    GROUP BY class;

或者:

    SELECT succ.class,succ.su AS \'及格\',fail.fa AS \'不及格\' FROM 
    (
    SELECT class,COUNT(1) AS su
    FROM gradeTable
    WHERE score >= 60
    GROUP BY class
    ) AS succ,
    (
    SELECT class,COUNT(1) AS fa
    FROM gradeTable
    WHERE score < 60
    GROUP BY class
    ) AS fail
    WHERE succ.class = fail.class;

Console : 

啦啦啦

 

 

啦啦啦

以上是关于MySQL -- 行转列 -- GROUP_CONCAT -- MAX(CASE WHEN THEN)的主要内容,如果未能解决你的问题,请参考以下文章

MySQL---行转列

mysql 行转列问题

mysql行转列的问题, 急!急!急!

mysql行转列的问题,但是否并接?

Mysql 行转列

mysql 动态行转列