一、行转列

须要将例如以下格式

转换为:

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

  1. create table test(
  2. id varchar2(255) primary key not null,
  3. name varchar2(255),
  4. course varchar2(255),
  5. score varchar2(255)
  6. );
  7. insert into test values(sys_guid(),'zhangsan','语文',85);
  8. insert into test values(sys_guid(),'zhangsan','数学',78);
  9. insert into test values(sys_guid(),'zhangsan','英语',90);
  10. insert into test values(sys_guid(),'lisi','语文',73);
  11. insert into test values(sys_guid(),'lisi','数学',84);
  12. insert into test values(sys_guid(),'lisi','英语',92);

行转列SQL语句为:

  1. select t.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 t
  6. group by t.name
  7. order by t.name

二、列转行

将例如以下格式

转换为

这就是最常见的列转行。主要原理是利用SQL里面的union

  1. create table test(
  2. id varchar2(255) primary key not null,
  3. name varchar2(255),
  4. ch_score   varchar2(255),
  5. math_score varchar2(255),
  6. en_score   varchar2(255)
  7. );
  8. insert into test values(sys_guid(),'zhangsan',88,76,90);
  9. insert into test values(sys_guid(),'lisi',91,67,82);

列转行SQL语句为:

  1. select name, '语文' COURSE , ch_score as SCORE from test
  2. union select name, '数学' COURSE, MATH_SCORE as SCORE from test
  3. union select name, '英语' COURSE, EN_SCORE as SCORE from test
  4. order by name,COURSE

IT忍者神龟之 oracle行转列、列转行的更多相关文章

  1. IT忍者神龟之Oracle DBA经常使用查询吐血列举

    –1. 查询系统全部对象 select owner, object_name, object_type, created, last_ddl_time, timestamp, status from ...

  2. Oracle 多行变一列的方法

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

  3. oracle 行转列、列转行

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

  4. oracle 行转列 分析函数

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

  5. Oracle 多行转多列

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

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

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

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

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

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

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

  9. oracle行锁select for update

    oracle行锁select for update 学习了:https://blog.csdn.net/zdwzzu2006/article/details/50490157 学习了:https:// ...

随机推荐

  1. ConcurrentBag扩展 批量加入

    public static void AddRange<T>(this ConcurrentBag<T> @this, IEnumerable<T> toAdd) ...

  2. 利用Squid + DNSPOD 搭建CDN服务器

    首先下载squid for windows安装包 squid-2.7.STABLE5-bin.zip 然后解压缩,放到C盘squid目录内. 进入目录C:\squid\etc内,将所有文件的.defa ...

  3. [翻译] FMDB

    FMDB https://github.com/ccgus/fmdb This is an Objective-C wrapper around SQLite: http://sqlite.org/ ...

  4. [翻译] INTERACTIVE TRANSITIONS 实时动态动画

    INTERACTIVE TRANSITIONS 实时动态动画 翻译不到位处敬请谅解,感谢原作者分享精神 原文链接 http://www.thinkandbuild.it/interactive-tra ...

  5. winform禁用标题栏

    protected override void WndProc(ref Message m) { if (m.Msg == 0x112) { switch ((int)m.WParam) { //禁止 ...

  6. javascript简单性能问题及学习笔记

    最近在看一本书:<高性能javaScript>,发现自己平时写js存在很多小细节上的问题,虽然这些问题不会导致程序运行出错,但是会导致界面加载变慢,用户体验变差,那么我们就来细细数一下应该 ...

  7. js cookie实例

    什么是cookie:           △ 用来保存用户信息:用户名.密码... ...           △ 同一网站共享一套cookie,大小有限,保存时间           △ 使用doc ...

  8. 基础学习:C#中float的取值范围和精度

    float类型的表现形式: 默认情况下,赋值运算符右侧的实数被视为 double. 因此,应使用后缀 f 或 F 初始化浮点型变量,如以下示例中所示: float x = 3.5F; 如果在以上声明中 ...

  9. c#写扩展方法

    学习MVC时,学会了写扩展方法,用起来很方便. 01 using System; 02 using System.Collections.Generic; 03 using System.Linq; ...

  10. android_orm框架之greenDAO(一)

    目录: 一.概述 二.下载并解压greenDAO相关资源 三.应用greenDAO框架 1.创建Java工程 2.添加类库支持 3.创建类 四.代码分析 五.使用greenDAO 六.源码下载 一.概 ...