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 : 

啦啦啦

 

 

啦啦啦

posted @   limeOracle  阅读(4125)  评论(2编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
点击右上角即可分享
微信分享提示