oracle行转列实现


1.新建测试表

create table TEST_TABLE(
T1 VARCHAR2(10),--姓名
T2 VARCHAR2(10),--科目
T3 VARCHAR2(10)--成绩
)

 

2.插入测试数据

insert into test_table (T1, T2, T3)
values ('张三', '语文', '88');

insert into test_table (T1, T2, T3)
values ('张三', '数学', '99');

insert into test_table (T1, T2, T3)
values ('张三', '英语', '100');

insert into test_table (T1, T2, T3)
values ('李四', '语文', '79');

insert into test_table (T1, T2, T3)
values ('李四', '数学', '100');

insert into test_table (T1, T2, T3)
values ('李四', '英语', '99');

insert into test_table (T1, T2, T3)
values ('王五', '语文', '99');

insert into test_table (T1, T2, T3)
values ('王五', '数学', '100');

insert into test_table (T1, T2, T3)
values ('王五', '英语', '98');

insert into test_table (T1, T2, T3)
values ('李六', '语文', '88');

insert into test_table (T1, T2, T3)
values ('李六', '英语', '99');

insert into test_table (T1, T2, T3)
values ('李六', '数学', '100');

 

3.行转列之前效果

我们先查询一下现在的效果

 

 

 4.下面是行转列写法

 select *  from test_table  pivot (max(T3) for T2 in(
 '语文' as 语文,
 '数学' as 数学,
 '英语' as 英语
 ))

效果如下:

 

 

 这样就非常简单的实现了。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM