ITPub博客

首页 > Linux操作系统 > Linux操作系统 > oracle中怎么实现行转列

oracle中怎么实现行转列

原创 Linux操作系统 作者:wengjie_0627 时间:2011-09-20 13:03:37 0 删除 编辑

在Oracle中行转列,可以利用decode函数:

如有学生表A:

ID NAME SUBJECT SCORE
1 张三 语文 90
2 张三 数学 80
3 李四 语文 99
4 李四 数学 78
5 张三 英语 89

现要转换成下表:

NAME 语文 数学 英语
张三 90 80 89
李四 99 78  

这是一个典型的行转列过程,只需如下SQL即可:

select NAME, sum(decode(SUBJECT,'语文', SCORE, null)), sum(decode(SUBJECT,'数学', SCORE, null)), sum(decode(SUBJECT,'英语', SCORE, null)) from A  group by NAME;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24984814/viewspace-707939/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2011-05-19

  • 博文量
    50
  • 访问量
    27850