Oracle行转列和列转行

一、行转列
1.1、初始测试数据

表结构:TEST_TB_GRADE

Sql代码:

1    create table TEST_TB_GRADE
2    (
3      ID        NUMBER(10) not null,
4      USER_NAME VARCHAR2(20 CHAR),
5      COURSE    VARCHAR2(20 CHAR),
6      SCORE     FLOAT
7    )

初始数据如下图:

1.2、 如果需要实现如下的查询效果图:

这就是最常见的行转列,主要原理是利用decode函数、聚集函数(sum),结合group by分组实现的,具体的sql如下:

Sql代码:
1    select t.user_name,
2      sum(decode(t.course, ‘语文‘, score,null)) as CHINESE,
3      sum(decode(t.course, ‘数学‘, score,null)) as MATH,
4      sum(decode(t.course, ‘英语‘, score,null)) as ENGLISH
5    from test_tb_grade t
6    group by t.user_name
7    order by t.user_name
1.3、延伸

如果要实现对各门功课的不同分数段进行统计,效果图如下:

具体的实现sql如下:
Sql代码:

01    select t2.SCORE_GP,
02      sum(decode(t2.course, ‘语文‘, COUNTNUM,null)) as CHINESE,
03      sum(decode(t2.course, ‘数学‘, COUNTNUM,null)) as MATH,
04      sum(decode(t2.course, ‘英语‘, COUNTNUM,null)) as ENGLISH
05    from (
06      select t.course,
07             case when t.score  <60 then ‘00-60‘
08                  when t.score >=60 and t.score <80  then ‘60-80‘
09                  when t.score >=80 then ‘80-100‘ end as SCORE_GP,
10             count(t.score) as COUNTNUM
11      FROM test_tb_grade t
12      group by t.course, 
13            case when t.score  <60  then ‘00-60‘
14                  when t.score >=60 and t.score <80  then ‘60-80‘
15                  when t.score >=80 then ‘80-100‘ end
16      order by t.course ) t2
17    group by t2.SCORE_GP
18    order by t2.SCORE_GP
二、列转行

1.1、初始测试数据
表结构: TEST_TB_GRADE2 
Sql代码:  
1    create table TEST_TB_GRADE2
2    (
3      ID         NUMBER(10) not null,
4      USER_NAME  VARCHAR2(20 CHAR),
5      CN_SCORE   FLOAT,
6      MATH_SCORE FLOAT,
7      EN_SCORE   FLOAT
8    )

初始数据如下图:

1.2、 如果需要实现如下的查询效果图:

这就是最常见的列转行,主要原理是利用SQL里面的union,具体的sql语句如下:
Sql代码:

1    select user_name, ‘CN_SCORE‘ COURSE , CN_SCORE as SCORE from test_tb_grade2 
2    union
3    select user_name, ‘MATH_SCORE‘ COURSE, MATH_SCORE as SCORE from test_tb_grade2 
4    union
5    select user_name, ‘EN_SCORE‘ COURSE, EN_SCORE as SCORE from test_tb_grade2 
6    order by user_name,COURSE

也可以利用【insert all into ... select】来实现,首先需要先建一个表TEST_TB_GRADE3:
Sql代码:  
1    create table TEST_TB_GRADE3  
2    ( 
3          USER_NAME VARCHAR2(20 CHAR),  
4          COURSE    VARCHAR2(20 CHAR),  
5          SCORE     FLOAT  
6    )
   
 再执行下面的sql: 
  Sql代码:  
1    insert all
2    into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, ‘语文‘, CN_SCORE)
3    into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, ‘数学‘, MATH_SCORE)
4    into test_tb_grade3(USER_NAME,COURSE,SCORE) values(user_name, ‘英语‘, EN_SCORE)
5    select user_name, CN_SCORE, MATH_SCORE, EN_SCORE from test_tb_grade2;
6    commit;

别忘记commit操作,然后再查询TEST_TB_GRADE3,发现表中的数据就是列转成行了。

时间: 2024-10-17 14:40:46

Oracle行转列和列转行的相关文章

oracle 行转列、列转行

最近做数据处理,经常遇到需要行转列.列转行的场景,记录个非常简单实用的oracle  列转行.行转的列方法 1.行转列,基础数据如下 做行转列处理 处理SQL select user_name,max(date_201501) as date_201501,max(date_201502),max(date_201503),max(date_201504) from (select t.user_name,case when t.acct_date = '201501' then t.flow

行转列,列转行

oracle: ----------------------------- 行转列  --------------------------------select * from democreate table demo(id int,name varchar(20),nums int);  ---- 创建表insert into demo values(1, '苹果', 1000);insert into demo values(2, '苹果', 2000);insert into demo

SQLServer处理行转列和列转行

掌握SQL Server 行转列和列转行 1.列转行 数据经过计算加工后会直接生成前端图表需要的数据源,但是程序里又需要把该数据经过列转行写入中间表中,下次再查询该数据时直接从中间表查询数据. 1.1 列换行语法 table_source UNPIVOT( value_column FOR pivot_column IN(<column_list>) ) 1.2  行转列案例 WITH T AS ( SELECT 1 as TeamId,'测试团队1' as Team,80 'MEN',20

做图表统计你需要掌握SQL Server 行转列和列转行

说在前面 做一个数据统计和分析的项目,每天面对着各种数据,经过存储过程从源表计算汇总后需要写入中间结果表以提高数据使用效率,那么此时就需要用到行转列和列转行. 1.列转行 数据经过计算加工后会直接生成前端图表需要的数据源,但是程序里又需要把该数据经过列转行写入中间表中,下次再查询该数据时直接从中间表查询数据. 1.1 列换行语法 table_source UNPIVOT( value_column FOR pivot_column IN(<column_list>) ) 1.2  行转列案例

oracle行转列

针对oracle数据查询的数据,行转列 1.wm_concat函数: 例一: select c1,c2,wm_concat(c3) from T where.... group by c1,c2 查询结果自动用","分割 例二: select c1,c2,wm_concat(c3)over(partition by ..order by..) from T where.... 其中,partition用来分组, order用来排序 2.sys_connect_by_path函数: 这个

重温SQL——行转列,列转行

行转列,列转行是我们在开发过程中经常碰到的问题.行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现.用传统的方法,比较好理解.层次清晰,而且比较习惯. 但是PIVOT .UNPIVOT提供的语法比一系列复杂的SELECT...CASE 语句中所指定的语法更简单.更具可读性.下面我们通过几个简单的例子来介绍一下列转行.行转列问题. 我们首先先通过一个老生常谈的例子,学生成绩表(下面简化了些)来形象了解下行转列 CREATE TAB

SQL——行转列,列转行

行转列,列转行是我们在开发过程中经常碰到的问题.行转列一般通过CASE WHEN 语句来实现,也可以通过 SQL SERVER 2005 新增的运算符PIVOT来实现.用传统的方法,比较好理解.层次清晰,而且比较习惯. 但是PIVOT .UNPIVOT提供的语法比一系列复杂的SELECT...CASE 语句中所指定的语法更简单.更具可读性.下面我们通过几个简单的例子来介绍一下列转行.行转列问题. 我们首先先通过一个老生常谈的例子,学生成绩表(下面简化了些)来形象了解下行转列 CREATE TAB

oracle 行转列 分析函数

oracle 行转列 首先看一下源数据: 方法一:WM_CONCAT group by 这个方法没有问题. SELECT CODE_TS, WMSYS.WM_CONCAT(S_NUM + 1 || ':' || ELEMENT) ELEMENT FROM T_MERCH_ELEMENT where code_ts='020745' group by CODE_TS; 得到的结果: 上面大家可能会发现序号没有按顺序排列下来.如果没有要求,就这样就可以了.如果要排序看方法二. 方法二:WM_CONC

sql 行转列 PIVOT 列转行 UNPIVOT

原文:sql 行转列 PIVOT 列转行 UNPIVOT 一: 现有表一(t_table1),想转为表二(t_table2)的格式. 表一: 年 公司 收入 2013 公司1 12 2013 公司2 22 2013 公司3 32 2012 公司1 42 2012 公司2 52 2012 公司3 62 表二: 年 公司1 公司2 公司3 2012 42 52 62 2013 12 22 32 可使用sql2005之后提供的PIVOT 具体操作如下: select * from   t_table1

行转列或列转行写法

原文:行转列或列转行写法 两种方式: /* 实现行转列 a name objec score a EN 89 a CH 78 a HO 99 b EN 34 b CH 88 b HO 66 要求输出结果为: name EN CH HO a 89 78 99 b 34 88 66 */ USE tempdb IF (SELECT 1 FROM sys.sysobjects WHERE name ='t' AND type='u') is NOT NULL DROP TABLE t CREATE T