码迷,mamicode.com
首页 > 数据库 > 详细

oracle行转列实现

时间:2019-12-07 14:40:20      阅读:66      评论:0      收藏:0      [点我收藏+]

标签:from   sele   weight   for   image   测试表   测试数据   pivot   har   

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 英语
 ))

效果如下:

技术图片

 

 

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

 

oracle行转列实现

标签:from   sele   weight   for   image   测试表   测试数据   pivot   har   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!