我们在写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>
本文介绍了一种使用SQL语句进行行列转换的方法,通过实例演示了如何利用Decode和Sum函数将成绩表从列式存储转为行式存储,方便进行数据分析。
1304

被折叠的 条评论
为什么被折叠?



