zoukankan      html  css  js  c++  java
  • oracle 使用 decode函数 或 case when 实现行转列

    ----创建测试表

    create table student_score(

           name varchar2(20),

           subject varchar2(20),

           score number(4,1)

     

    );

     

    -----插入测试数据

    insert into student_score (name,subject,score)values('张三','语文',78);

     

    insert into student_score (name,subject,score)values('张三','数学',88);

     

    insert into student_score (name,subject,score)values('张三','英语',98);

     

     

    insert into student_score (name,subject,score)values('李四','语文',89);

     

    insert into student_score (name,subject,score)values('李四','数学',76);

     

    insert into student_score (name,subject,score)values('李四','英语',90);

     

     

    insert into student_score (name,subject,score)values('王五','语文',99);

     

    insert into student_score (name,subject,score)values('王五','数学',66);

     

    insert into student_score (name,subject,score)values('王五','英语',91);

     

    -----decode行转列

    select name "姓名",

           sum(decode(subject, '语文', nvl(score, 0), 0)) "语文",

           sum(decode(subject, '数学', nvl(score, 0), 0)) "数学",

           sum(decode(subject, '英语', nvl(score, 0), 0)) "英语"

      from student_score

     group by name;

     

    ------ case when 行转列

     

    select name "姓名",

           sum(case when subject='语文'

           then nvl(score,0)

           else 0

           end) "语文",

           sum(case when subject='数学'

           then nvl(score,0)

           else 0

           end) "数学",

           sum(case when subject='英语'

           then nvl(score,0)

           else 0

           end) "英语"

          from student_score

           group by name;

  • 相关阅读:
    python基础day3-今日内容,2019-6-25
    python基础day3-视频下载,2019-6-25
    append,extend,insert的区别
    DOM基础之获取元素
    p1553数组反转
    python函数
    python文件处理
    day02 python基础之列表,元祖,字典
    day01 python基础
    Python绘图Turtle库详解
  • 原文地址:https://www.cnblogs.com/hqbhonker/p/3341239.html
Copyright © 2011-2022 走看看