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

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. ubuntu下删除和新建用户(并有su权限)

    http://blog.csdn.net/speedme/article/details/8206144ubuntu下删除和新建用户(并有su权限) 如何创建ubuntu新用户?输入:sudo add ...

  2. Pro ASP.NET Core MVC 第6版翻译 目录页

    Pro ASP.NET Core MVC 第6版 目录 第一部分 第一章 ASP.NET Core MVC 的前世今生 第二章 第一个MVC应用程序(上) 第二章 第一个MVC应用程序(下) 第三章 ...

  3. 求助:可以使用任何编程工具做成一个控件或组件,使得在VB中能调用并得到摄像头的参数及图片。

    请看下网址上的这个问题,看是否有解决的方式http://www.educity.cn/wenda/338634.html

  4. 【转载】testlink 1.8.5 安装错误的解决方法

    TestLink所需环境为PHP+MYSQL (支持MS SQL等),系统推荐使用PHP5.2,安装成功以后,如果运行时出错,主要两种错: [1].HP Warning: strtotime(): I ...

  5. karma+requirejs+angular 测试

    http://karma-runner.github.io/0.8/plus/RequireJS.html karma 不是测试框架,只是一个运行测试框架的服务器 karma测试的原理是,将所有的文件 ...

  6. Spartan6系列之GTP Transceiver的介绍与使用

    1.       什么是GTP transceiver? GTP transceiver是FPGA里一种线速度达500Mb/sà6.6Gb/s的收发器,利用FPGA内部可编程资源可对其进行灵活地配置, ...

  7. jsp学习笔记 - 内置对象 pageContext

    1.pageContext几乎可以操作所有的页面内置对象 pageContext.getRequest();    得到的对象只是属于ServletRequest类,httpServletReques ...

  8. std list/vector sort 自定义类的排序就是这么简单

    所以,自己研究了一下,如下:三种方式都可以,如重写<,()和写比较函数compare_index.但是要注意对象和对象指针的排序区别. 1.容器中是对象时,用操作符<或者比较函数,比较函数 ...

  9. CAD使用GetxDataDouble读数据(网页版)

    主要用到函数说明: MxDrawEntity::GetxDataDouble2 读取一个Double扩展数据,详细说明如下: 参数 说明 [in] LONG lItem 该值所在位置 [out, re ...

  10. (独孤九剑)--MySQL入门

    :[一]概论 (1)什么是 MySQL? 一种关系型开源数据库,定义了存储信息的结构. 在数据库中,存在着一些表.类似 HTML 表格,数据库表含有行.列以及单元. 在分类存储信息时,数据库非常有用. ...