在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/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/24984814/viewspace-707939/