天天看点

Oracle 行转列两种方法

1.新建一个名为test表

2.向test表中添加数据

insert into test(student,course,score)

select '张三','语文',78 from dual union

select '张三','数学',87 from dual union

select '张三','英语',82 from dual union

select '张三','物理',90 from dual union

select '李四','语文',65 from dual union

select '李四','数学',77 from dual union

select '李四','英语',65 from dual union

select '李四','物理',85 from dual

表数据如下:

Oracle 行转列两种方法

3.列转行

方法··1:

select

    student,

    sum(decode(course, '数学', score)) 数学,

    sum(decode(course, '物理', score)) 物理,

    sum(decode(course, '英语', score)) 英语,

    sum(decode(course, '语文', score)) 语文

from

    test

group by student

方法··2:

    sum(case course when '数学' then score else null end) 数学,

    sum(case course when '物理' then score else null end) 物理,

    sum(case course when '英语' then score else null end) 英语,

    sum(case course when '语文' then score else null end) 语文

效果如下:

Oracle 行转列两种方法

注:sum是求和的意思;比如说里面记录里面有两条张三,列转行显示的结果就会是两个张三的结果之和。

继续阅读