sql行转列

将行转换为列通常可以通过使用 CASE 表达式和聚合函数来实现。这种操作有时也被称为数据透视。

输出报表的需求中,经常会遇到行转列的诉求,巧妙利用目前sql中具有的函数可以优雅的解决这些问题

练习示例:

比如我现在有一张学生成绩表

其中包含了学生的姓名、学号和他们各科的成绩等

 

现在我们需要在报表上直观的看到学习的各科成绩,则是把学生的成绩转成列

要求:学号 、姓名、数学分数、语文分数

 

SELECT 
    stuNum,stuName,
    MAX(CASE WHEN subject = '数学' THEN score END) AS math_score,
    MAX(CASE WHEN subject = '语文' THEN score END) AS chinese_score
FROM 
    student_score
GROUP BY 
    stuNum,stuName

 CASE WHEN 作为判断条件来帮助我们拆分以前的行变成列。

当然我们还可以利用IF(expr1,expr2,expr3)函数(根据数据库类型选择对应函数)来实现

SELECT 
    stuNum,stuName,
    MAX(IF(subject = '数学',score,0.00)) AS math_score,
    MAX(IF(subject = '语文',score,0.00)) AS chinese_score
FROM 
    student_score
GROUP BY 
    stuNum,stuName

如果你的拆分逻辑较为复杂,也可以再接上if上接and条件来处理

SELECT 
    stuNum,stuName,
    MAX(IF(subject = '数学' and score>95,score,'**')) AS math_score,
    MAX(IF(subject = '语文' and score>95,score,'**')) AS chinese_score
FROM 
    student_score
GROUP BY 
    stuNum,stuName

 这里千万注意前面有MAX函数,所以不满足条件的部分不要换成字符串,否则和预期值不一样,原因大家自行查阅分析

posted @ 2024-03-08 12:12  勇攀顶峰  阅读(28)  评论(0编辑  收藏  举报