一、行转列
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,发现表中的数据就是列转成行了。
原文地址:http://www.2cto.com/database/201108/100792.html

Oracle 行转列,列转行的更多相关文章

  1. oracle 行转列、列转行

    最近做数据处理,经常遇到需要行转列.列转行的场景,记录个非常简单实用的oracle  列转行.行转的列方法 1.行转列,基础数据如下 做行转列处理 处理SQL select user_name,max ...

  2. oracle行转列、列转行、连续日期数字实现方式及mybatis下实现方式

    转载请注明出处:https://www.cnblogs.com/funnyzpc/p/9977591.html 九月份复习,十月份考试,十月底一直没法收心,赶在十一初 由于不可抗拒的原因又不得不重新找 ...

  3. Oracle 行转列pivot 、列转行unpivot 的Sql语句总结

    这个比较简单,用||或concat函数可以实现 select concat(id,username) str from app_user select id||username str from ap ...

  4. Oracle 行转列及列转行

    参考网址:http://blog.163.com/fushahui_1988@126/blog/static/82879994201192844355174/ 一.多行转一列select id, vn ...

  5. Oracle 多行变一列的方法

    多行变一列的方法有很多,觉得这个第一眼看懂了当时就用的这个办法. 情况是这样的.以下数据前几列是一样的,需要把VAT_VALUE_CHAR 的值放在同一行上. SELECT * FROM ps_vat ...

  6. oracle 多行转多列查询

     oracle 多行转多列查询  ---create table Fruit(id int,name varchar(20), Q1 int, Q2 int, Q3 int, Q4 int);inse ...

  7. oracle 行转列 分析函数

    oracle 行转列 首先看一下源数据: 方法一:WM_CONCAT group by 这个方法没有问题. SELECT CODE_TS, WMSYS.WM_CONCAT(S_NUM + || ':' ...

  8. Oracle 多行转多列

    Oracle 多行转多列,列值转为列名   前段时间做调查问卷,客户创建自定义问卷内容,包括题目和选项内容; 之后需要到处问卷明细,,,,麻烦来咯 于是到网上到处搜索,没有直接结果;于是又找各种相似的 ...

  9. SQL Server 行转列,列转行。多行转成一列

    一.多行转成一列(并以","隔开) 表名:A 表数据: 想要的查询结果: 查询语句: SELECT name , value = ( STUFF(( SELECT ',' + va ...

  10. Oracle字符串行拆分成列的三种方式

    Oracle字符串行拆分成列的三种方式 --muphy 开发过程中经常会遇到将前台多个值用逗号连接一同传递到后台查询,这个用逗号连接的字符串分隔的每个字符串分别对应Oracle数据库表的不同行. 如下 ...

随机推荐

  1. 巧用用layer-list做一个卡片背景

    <?xml version="1.0" encoding="utf-8"?> <layer-list xmlns:android=" ...

  2. ios线程和GCD

    1.什么是进程? 进程是指在系统中正在运行的一个应用程序.比如同时打开QQ.Xcode,系统就会分别启动2个进程.截图 2.什么是线程? 1).一个进程要想执行任务,必须得有线程(每一个进程至少要有一 ...

  3. TextView显示颜色高亮的问题

    TextView textView = (TextView) findViewById( R.id.tv ); String text = "<font color=\"#d ...

  4. iOS数据缓存及YYCache的实现分析

    1. 什么是cache cache就是缓存的意思. 计算机上的cache就是高速缓存,计算机组成课程里的定义是,存在于主存和CPU之间,主要用于解决CPU处理数据的速度远远大于读取主存数据的速度. 手 ...

  5. 【代码笔记】iOS-饼图

    一,效果图. 二,工程图. 三,代码. RootViewController.h #import <UIKit/UIKit.h> @class QuizChartView; @interf ...

  6. Java基础知识学习(二)

    Java语法基础 数据类型.类型转换.运算符.逻辑运算符.参考C#,基本一致 输入输出 输出 System.out.print("abc"); System.out.printf( ...

  7. (企业面试部分)超详细思路讲解SQL语句的查询实现,及数据的创建。

    企业面试部分详细的SQL问题,思路讲解 第一步:创建数据库表,及插入数据信息 --Student(S#,Sname,Sage,Ssex) 学生表 CREATE TABLE student( sno ) ...

  8. 查看Android支持的硬解码信息

    通过/system/etc/media_codecs.xml可以确定当前设备支持哪些硬解码.通过/system/etc/media_profiles.xml可以知道设备支持的具体profile和lev ...

  9. 知道创宇研发技能表v3.1

    by @知道创宇(www.knownsec.com) @余弦 & 404团队 后续动态请关注微信公众号:Lazy-Thought 说明 关于知道创宇 知行合一 | 守正出奇 知道创宇是一家黑客 ...

  10. 初学git,出现错误:fatal: Not a git repository (or any of the parent directories): .git

    提示说没有.git这样一个目录,解决办法: 输入  git init 就可以啦.