zoukankan      html  css  js  c++  java
  • Oracle: Oracle行转列、列转行的Sql语句总结

    例子原型:

    select bkg_num,shpr_cde from CD_XLS_UPLOAD_DETAIL where  cd_xls_upload_uuid='392' ;

    运行结果如下:

    一、多字段的拼接

     将两个或者多个字段拼接成一个字段:

    select bkg_num||shpr_cde from CD_XLS_UPLOAD_DETAIL where  cd_xls_upload_uuid='392' ;

    运行结果:

    二、行转列

    将某个字段的多行结果,拼接成一个字段,获取拼接的字符串【默认逗号隔开】

    select   wm_concat(bkg_num) from CD_XLS_UPLOAD_DETAIL where  cd_xls_upload_uuid='392' ;

    运行结果:

    6098621760,6098621760

    开拓:如果不想用逗号隔开,可以进行替换:

    select replace(wm_concat(bkg_num),',','|') from test;

      也可以进行分组的拼接:

    select id,wm_concat(bkg_num) name from test group by id;

    三、列转行

    原图如下:

    转成行的形式:

    实现的sql:

    create table demo(id int,name varchar(20),nums int); ---- 创建表
    insert into demo values(1, 'apple', 1000);
    insert into demo values(2, 'apple', 2000);
    insert into demo values(3, 'apple', 4000);
    insert into demo values(4, 'orange', 5000);
    insert into demo values(5, 'orange', 3000);
    insert into demo values(6, 'grape', 3500);
    insert into demo values(7, 'mango', 4200);
    insert into demo values(8, 'mango', 5500);
    commit;
    select name, sum(nums) from demo group by name;
    select * from (select name, nums from demo) pivot(sum(nums) for name in ('apple','orange','grape','mango'));  --实现sql

    注意: pivot(聚合函数 for 列名 in(类型)) ,其中 in('') 中可以指定别名,in中还可以指定子查询,比如 select distinct code from customers

    指定别名如:

    select * from (select name, nums from demo) pivot(sum(nums) for name in ('apple' 苹果,'orange' 橘子,'grape' 葡萄,'mango' 芒果));  

  • 相关阅读:
    ExtJs gridPanel Column 时间格式化
    Asp.Net MVC结合ExtJs gridPanel 分页和高度自适应
    iOS组件化思路-大神博客研读和思考
    怎么面试架构师
    iOS应用架构谈 本地持久化方案及动态部署
    iOS应用架构谈 网络层设计方案
    iOS应用架构谈 view层的组织和调用方案
    iOS应用架构谈 开篇
    隐藏TabBar是个累人的活
    App升级时数据库的迁移更新
  • 原文地址:https://www.cnblogs.com/renxiaoren/p/5512096.html
Copyright © 2011-2022 走看看