oracle 行转列 首先看一下源数据:

方法一:WM_CONCAT group by 这个方法没有问题。

SELECT CODE_TS,
            WMSYS.WM_CONCAT(S_NUM +  || ':' || ELEMENT) ELEMENT
        FROM T_MERCH_ELEMENT '  group by CODE_TS;

得到的结果:

上面大家可能会发现序号没有按顺序排列下来。如果没有要求,就这样就可以了。如果要排序看方法二。

方法二:WM_CONCAT OVER  有特殊数据时会报错。报:“操作数值超出系统的限制”。原因我不知道,谁知道麻烦告诉我一下。

select * from (  

SELECT CODE_TS,
            WMSYS.WM_CONCAT(S_NUM +  || ':' || ELEMENT) OVER(ORDER BY S_NUM) ELEMENT,
             TO_NUMBER(DENSE_RANK()
                       OVER(PARTITION BY CODE_TS ORDER BY S_NUM DESC)) ORDERNO
        FROM T_MERCH_ELEMENT ' ORDER BY CODE_TS,S_NUM

        )t ;

WM_CONCAT OVER

如果不报错效果:

方法三:sys_connect_by_path over 这个方法没有问题。但有注意点:sys_connect_by_path  这里的连接符号不要使用逗号,oracle会报错,如果一定要用,可以使用replace替换一下;连接符不可以在你的第一个参数列中存在。你可以用多个组合连接符。

那样就不容易在你的列中存在,我这里用了;加空格。当然你也可以用一个肯定不存在的组合连接符,然后把不需要的部分连接符replace掉

select CODE_TS,ELEMENT from
(
        select CODE_TS,ELEMENT,
  row_number() over(partition by CODE_TS order by CODE_TS,rank desc) ename_path_rank
  from (

     select CODE_TS,rank,
                 ltrim(sys_connect_by_path(rank||':'||ELEMENT,'; '),'; ') ELEMENT  from
                 (
                   select CODE_TS,ELEMENT,row_number() over(partition by CODE_TS order by s_num desc) rank
                   '
                    order by s_num desc
                 ) connect by CODE_TS = prior CODE_TS and rank- = prior rank
       )
       )
;

sys_connect_by_path

效果如下图:

oracle 行转列 分析函数的更多相关文章

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

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

  2. oracle行转列(连接字符串函数)

    方法一:wmsys.wm_concat(column) 介绍:其函数在Oracle 10g推出,在10g版本中,返回字符串类型,在11g版本中返回clob类型.括号里面的参数是列,而且可以是多个列的集 ...

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

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

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

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

  5. oracle 行转列、列转行

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

  6. Oracle行转列操作

    有时候我们在展示表中数据的时候,需要将行转为列来显示,如以下形式: 原表结构展示如下:---------------------------产品名称    销售额     季度------------ ...

  7. Oracle行转列的函数

    --行转列的函数-- CREATE OR REPLACE FUNCTION Calvin( col IN VARCHAR2,dw IN VARCHAR2) RETURN VARCHAR2 IS ret ...

  8. oracle 行转列 列转行

    行转列 这是一个Oracle的列转行函数:LISTAGG() 先看示例代码: with temp as( select 'China' nation ,'Guangzhou' city from du ...

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

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

随机推荐

  1. Agile software architecture design document style..( sketches and no UMLs)

    http://www.infoq.com/articles/agile-software-architecture-sketches-NoUML If you're working in an agi ...

  2. 5个让DBA爱上你的SQL技巧

    我的一个同事Martin Masarik,SQLde的CEO,跟我谈起了他的一个DBA朋友,他管理着一个国际银行的Oracle数据库,数据规模约2TB.Martin Masarik曾问他:“什么样的S ...

  3. Hibernate悲观锁/乐观锁

    如果需要保证数据访问的排它性,则需对目标数据加"锁",使其无法被其它程序修改 一,悲观锁 对数据被外界(包括本系统当前的其它事务和来自外部系统的事务处理)修改持保守态度,通过数据库 ...

  4. Redis中的关系查询(范围查询,模糊查询等...)

    本文部分转自于:http://blog.csdn.net/dc_726/article/details/42784317 本文对Redis如何保存关系型数据,以及如何对其匹配.范围.模糊查询进行举例讲 ...

  5. Oracle查找被长时间锁定的对象并kill

    1.用如下语句查找被锁住的表名.OSclient.Session信息 SELECT B.SID         ,B.SERIAL#         ,D.SPID        OS系统进行号    ...

  6. 关于servlet与jsp&java类传值问题

    为了实现单击左侧导航栏,动态改变右侧(一个jsp文件)的内容,需要改变变量var的值,进而实现改变default部分内容的目的(自己想的方法,因为实在是layman.应该有简便快捷的方法,可我不知道. ...

  7. sort排序中的坑

    问题的产生原因: 在一篇阿里面试题的跟帖中,很多人应用sort()方法对数组进行排序.看似合情合理的代码,运行结果却频频出错.为什么呢?因为很多人都忽略掉了一点,那就是sort()排序默认情况下是按A ...

  8. HttpClient(4.3.5) - HTTP Entity

    HTTP entity HTTP messages can carry a content entity associated with the request or response. Entiti ...

  9. Android 分析工具 APKAnalyser

    APKAnalyser 是 Android 静态,虚拟分析工具,用来测试和验证 Android 应用的开发工作.ApkAnalyser 是个完整的工具链,可以修改二进制应用.用户可以改装,安装,运行, ...

  10. 基于asp.net的ajax分页

    直接贴代码: <html> <head> <meta http-equiv="Content-Type" content="text/htm ...