需求是,统计每一个部门不同工种的薪水总和。

SQL> select deptno,ename,job,sal from emp;

    DEPTNO ENAME      JOB              SAL

---------- ---------- --------- ----------

        20 SMITH      CLERK            800

        30 ALLEN      SALESMAN        1600

        30 WARD       SALESMAN        1250

        20 JONES      MANAGER         2975

        30 MARTIN     SALESMAN        1250

        30 BLAKE      MANAGER         2850

        10 CLARK      MANAGER         2450

        20 SCOTT      ANALYST         3000

        10 KING       PRESIDENT       5000

        30 TURNER     SALESMAN        1500

        20 ADAMS      CLERK           1100

        30 JAMES      CLERK            950

        20 FORD       ANALYST         3000

        10 MILLER     CLERK           1300

已选择14行。



SQL> select deptno,

           nvl(sum(decode(job, 'MANAGER', sal)), 0) "s_MANAGER",

           nvl(sum(decode(job, 'ANALYST', sal)), 0) "s_ANALYST",

           nvl(sum(decode(job, 'CLERK', sal)), 0) "s_CLERK",

           nvl(sum(decode(job, 'PRESIDENT', sal)), 0) "s_PRESIDENT",

           nvl(sum(decode(job, 'SALESMAN', sal)), 0) "s_SALESMAN"

      from emp

     group by deptno;

    DEPTNO  s_MANAGER  s_ANALYST    s_CLERK s_PRESIDENT s_SALESMAN

---------- ---------- ---------- ---------- ----------- ----------

        30       2850          0        950           0       5600

        20       2975       6000       1900           0          0

        10       2450          0       1300        5000          0

SQL> select deptno,

           nvl(sum(case job when 'MANAGER' then sal else null end), 0) "s_MANAGER",

           nvl(sum(case job when 'ANALYST' then sal else null end), 0) "s_ANALYST",

           nvl(sum(case job when 'CLERK' then sal else null end), 0) "s_CLERK",

           nvl(sum(case job when 'PRESIDENT' then sal else null end), 0) "s_PRESIDENT",

           nvl(sum(case job when 'SALESMAN' then sal else null end), 0) "s_SALESMAN"

      from emp

     group by deptno;



    DEPTNO  s_MANAGER  s_ANALYST    s_CLERK s_PRESIDENT s_SALESMAN

---------- ---------- ---------- ---------- ----------- ----------

        30       2850          0        950           0       5600

        20       2975       6000       1900           0          0

        10       2450          0       1300        5000          0

需求是查询每一个部门下的人员信息,在一行显示。在oracle 10g和11g上能够用WMSYS.WM_CONCAT,但值得注意的是此函数是undocument的函数(不是官方发布的函数),oracle不保证升级之后还会存在。

SQL> SELECT deptno, WMSYS.WM_CONCAT(ename) AS employees FROM emp GROUPBY deptno;

DEPTNO EMPLOYEES

---------- --------------------------------------

10 CLARK,MILLER,KING

20 SMITH,FORD,ADAMS,SCOTT,JONES

30ALLEN,JAMES,TURNER,BLAKE,MARTIN,WARD

Oracle 11g后,能够用listagg实现。

SQL> SELECT deptno, LISTAGG(ename, ',') WITHIN

GROUP( ORDER BY ename) AS employees

FROM emp

GROUP BY deptno;

DEPTNO EMPLOYEES

---------- ---------------------------------------

10 CLARK,KING,MILLER

20ADAMS,FORD,JONES,SCOTT,SMITH

30ALLEN,BLAKE,JAMES,MARTIN,TURNER,WARD

Oracle 简单的列转行的更多相关文章

  1. Oracle 四种列转行的方法

    1. Oracle自带列转行函数listagg: 实例: with temp as( select 'China' nation ,'Guangzhou' city from dual union a ...

  2. Oracle中的列转行实现字段拼接用例

    文章目录 Oracle中的列转行实现字段拼接 场景 在SQL使用过程中经常有这种需求:将某列字段拼接成in('XX','XX','XX','XX','XX','XX' ...)做为查询条件. 实现 s ...

  3. Oracle中的列转行例子详解

    数据如下:name id张三 1,2,3 要求实现:name id张三 1张三 2张三 3 --创建临时表 create table tmp as(select '张三' name, '1,2,3' ...

  4. Oracle wm_concat(列转行函数)实际使用

    接触到了一个开发需求.其中是要把NC单据表体行的字段拼成一个字符串.例如: id name work age 1 王一 搬运工 20 2 李二 清洁工 21 3 张三 洗脚工 22 出现结果字符串为: ...

  5. oracle wm_concat函数 列转行 分组函数

    (1)select mark, wm_concat(status) from DISSENT_INFO t GROUP BY mark; 查出来的数据 mark     status 222      ...

  6. Oracle行转列、列转行的Sql语句总结

    多行转字符串 这个比较简单,用||或concat函数可以实现  SQL Code  12    select concat(id,username) str from app_userselect i ...

  7. Oracle行转列、列转行的Sql语句总结(转)

    多行转字符串 这个比较简单,用||或concat函数可以实现 select concat(id,username) str from app_userselect id||username str f ...

  8. oracle 行转列、列转行

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

  9. oracle中行转列、列转行函数

    多行转字符串 这个比较简单,用||或concat函数可以实现 select concat(id,username) str from app_user select id||username str ...

随机推荐

  1. es6之iterator,for...of

    遍历器(Iterator)是一种统一的接口机制,来处理所有不同的数据结构. JavaScript 原有的表示“集合”的数据结构,主要是数组(Array)和对象(Object),ES6 又添加了Map和 ...

  2. Android常用依赖库搜集

    图片处理 CircleImageView Git地址:https://github.com/hdodenhof/CircleImageView 图片依赖库 glide Git地址:https://gi ...

  3. TCP/IP和UDP的比较

    TCP.UDP详解 1.传输层存在的必要性 由于网络层的分组传输是不可靠的,无法了解数据到达终点的时间,无法了解数据未达终点的状态.因此有必要增强网络层提供服务的服务质量. 2.引入传输层的原因 面向 ...

  4. linux使用crontab实现PHP执行计划定时任务

    linux使用crontab实现PHP执行计划定时任务 前几天写过一篇文章,利用单纯的php实现定时执行任务,但是效率不佳,对于linux来说用crontab实现更加合理 首先说说cron,它是一个l ...

  5. Jmeter之JDBC请求参数化(一)

    一.环境准备 a.jmeter5.1.1版本最新版本,可以去网页下载:https://jmeter.apache.org/download_jmeter.cgi b.jdbc驱动:链接:https:/ ...

  6. 梦想CAD控件网页版标注样式

    增加标注样式 _DMxDrawX::AddDimStyle 增加一个新的标注样式,如果当前已经有指定名的标注样式,就直接失败返回.详细说明如下: 参数 说明 BSTR pszName 新增加的标注样式 ...

  7. (C/C++学习)16.函数指针

    说明:函数指针,顾名思义就是指向函数的指针.C/C++中函数名的本质其实就是一段代码段空间的首地址. 1.定义 如下的 pf 就是一个函数指针,指向所有返回类型为 int,并带有两个 const in ...

  8. 每日命令:(10)cat

    cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用. 1.命令格式: cat [选项] [文件] ...

  9. importdata-- matlab

    source file: test.dat *************************** Day1  Day2  Day3  Day4  Day5  Day6  Day795.01 76.2 ...

  10. extract a page from a multiple pages pdf on Ubuntu OS

    extract a page from a multiple pages pdf 1 extract a page from a multiple pages pdf use pdftk packag ...