zoukankan      html  css  js  c++  java
  • oracle中行转列操作

    数据准备阶段:

    CREATE TABLE CC  (Student NVARCHAR2(2),Course NVARCHAR2(2),Score INT); 

    INSERT into CC   
    select N'张三',N'语文',78 from dual union all  
    select N'张三',N'数学',87 from dual union all  
    select N'张三',N'英语',82 from dual union all  
    select N'张三',N'物理',90 from dual union all  
    select N'李四',N'语文',65 from dual union all  
    select N'李四',N'数学',77 from dual union all  
    select N'李四',N'英语',65 from dual union all  
    select N'李四',N'物理',85 from dual ;  
    commit; 

    操作如下:

    方法一、

    select 
    student,
    sum(decode(course,'语文',score)) 语文,
    sum(decode(course,'数学',score)) 数学,
    sum(decode(course,'英语',score)) 英语,
    sum(decode(course,'物理',score)) 物理,
    sum(score)
    from cc group by student;

     方法二、

    SELECT KIN.*,  
      KIN.a+KIN.b+KIN.c+KIN.d AS TOTAL  
    FROM  
      (SELECT   *  
      FROM CC PIVOT ( MAX(SCORE) FOR COURSE IN ('语文' AS A , '数学' AS B, '英语' AS C,'物理' AS D) )  
      ) KIN; 

    方法三、

    select 
    student,
    sum(case when course = '语文' then score else 0 end )语文,
    sum(case when course = '数学' then score else 0 end )数学,
    sum(case when course = '英语' then score else 0 end )英语,
    sum(case when course = '物理' then score else 0 end )物理
    from cc group by student;

    完。

  • 相关阅读:
    递归和回溯的区别
    N皇后问题
    c输出格式
    python sublime run快捷键设置
    八皇后问题
    动态规划---从左上角到右下角的价值最大的路径
    莫队算法详解和c实现
    Shell 常用命令总结
    WeakHashMap和HashMap的区别
    【 Jquery插件】引导用户如何操作网站功能的向导
  • 原文地址:https://www.cnblogs.com/hello-wei/p/10283527.html
Copyright © 2011-2022 走看看