zoukankan      html  css  js  c++  java
  • (转)Oracle中实现行列转换的方法

    (转自)http://blog.csdn.net/Torrice/archive/2006/01/25/587986.aspx
    我们在写SQL语句的时候经常需要用到行与列的转换问题,对于一个新手来说可能比较困难,其实你只要能够熟练运用Decode和Sum函数,这个问题就迎刃而解.



    Create   table   test   (name   char(10),km   char(10),cj   Number)

    insert   into   test   values('张三','语文',80)
    insert   into   test   values('张三','数学',86)
    insert   into   test   values('张三','英语',75)
    insert   into   test   values('李四','语文',78)
    insert   into   test   values('李四','数学',85)
    insert   into   test   values('李四','英语',78)

    commit;



    怎样实现成这样:
    name     语文     数学     英语
    李四     78         85         83
    张三     80         86         75

    16:03:50   SQL>   select   *   from   test;

    NAME               KM                                   CJ
    ----------   ----------   ----------
    张三               语文                               80
    张三               数学                               86
    张三               英语                               75
    李四               语文                               78
    李四               数学                               85
    李四               英语                               78

    已选择6行。

    已用时间:     00:   00:   00.47



    16:03:55   SQL>   select   name,sum(decode(trim(km),'语文',cj,0))   语文,
    16:03:58       2     sum(decode(trim(km),'数学',cj,0))   数学,
    16:03:58       3     sum(decode(trim(km),'英语',cj,0))   英语
    16:03:59       4     from   test   group   by   name;

    NAME                           语文               数学               英语
    ----------   ----------   ----------   ----------
    李四                               78                   85                   78
    张三                               80                   86                   75



    已用时间:     00:   00:   00.15
    16:03:59   SQL>

  • 相关阅读:
    链表面试题Java实现【重要】
    数据结构Java实现05----栈:顺序栈和链式堆栈
    数据结构Java实现06----中缀表达式转换为后缀表达式
    数据结构Java实现07----队列:顺序队列&顺序循环队列、链式队列、顺序优先队列
    栈和队列的面试题Java实现,Stack类继承于Vector这两个类都不推荐使用
    MySQL多表查询之外键、表连接、子查询、索引
    MySQL字符串函数、日期时间函数
    sqlplus登录、连接命令
    LeetCode 68 Text Justification
    cocos2d触摸事件处理机制(2.x和3.x变化)
  • 原文地址:https://www.cnblogs.com/spymaster/p/912070.html
Copyright © 2011-2022 走看看