oracle行转列实现

时间:2019-12-07
本文章向大家介绍oracle行转列实现,主要包括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 英语
 ))

效果如下:

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

原文地址:https://www.cnblogs.com/zjc2018/p/12001453.html