Oracle数据库中行转列(在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;
原文出自【比特网】,转载请保留原文链接:http://soft.chinabyte.com/database/262/12145762.shtml