oracle 行转列 分析函数
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 行转列 分析函数的更多相关文章
- Oracle 行转列pivot 、列转行unpivot 的Sql语句总结
这个比较简单,用||或concat函数可以实现 select concat(id,username) str from app_user select id||username str from ap ...
- oracle行转列(连接字符串函数)
方法一:wmsys.wm_concat(column) 介绍:其函数在Oracle 10g推出,在10g版本中,返回字符串类型,在11g版本中返回clob类型.括号里面的参数是列,而且可以是多个列的集 ...
- Oracle行转列、列转行的Sql语句总结
多行转字符串 这个比较简单,用||或concat函数可以实现 SQL Code 12 select concat(id,username) str from app_userselect i ...
- Oracle行转列、列转行的Sql语句总结(转)
多行转字符串 这个比较简单,用||或concat函数可以实现 select concat(id,username) str from app_userselect id||username str f ...
- oracle 行转列、列转行
最近做数据处理,经常遇到需要行转列.列转行的场景,记录个非常简单实用的oracle 列转行.行转的列方法 1.行转列,基础数据如下 做行转列处理 处理SQL select user_name,max ...
- Oracle行转列操作
有时候我们在展示表中数据的时候,需要将行转为列来显示,如以下形式: 原表结构展示如下:---------------------------产品名称 销售额 季度------------ ...
- Oracle行转列的函数
--行转列的函数-- CREATE OR REPLACE FUNCTION Calvin( col IN VARCHAR2,dw IN VARCHAR2) RETURN VARCHAR2 IS ret ...
- oracle 行转列 列转行
行转列 这是一个Oracle的列转行函数:LISTAGG() 先看示例代码: with temp as( select 'China' nation ,'Guangzhou' city from du ...
- oracle行转列、列转行、连续日期数字实现方式及mybatis下实现方式
转载请注明出处:https://www.cnblogs.com/funnyzpc/p/9977591.html 九月份复习,十月份考试,十月底一直没法收心,赶在十一初 由于不可抗拒的原因又不得不重新找 ...
随机推荐
- Mac OS恢复出厂系统方法
1.重新启动时按住“Command()”和"R"键盘 2.选择磁盘工具
- saltstack实战3--配置管理之YAML语法
本文来自如下链接http://docs.saltstack.cn/topics/yaml/index.html 了解YAML 默认的SLS文件的renderer是YAML renderer.YAML是 ...
- Web.config加密和解密
在系统部署的时候,大家都会遇到关于用户凭证的安全性问题,而对于数据库连接的相关的信息,有些时候客户也需要我们对其加密,防止信息泄露,在此将加密和解的方法记录于此: 首先用管理员的权限启动cmd命令窗口 ...
- Features for configuring JSON-to-Java mapping
Following on/off features are defined in DeserializationConfig.Feature (Jackson 1.x) or Deserializat ...
- DialogFragment
DialogFragment 从Android 3.0 (API level 11)开始引入,如果想在低于该版本的系统上使用,需用android.support.v4.app.DialogFragme ...
- 如何用代码开启“个人热点”功能?如何用代码把iOS设备设置成一个无线路由?
不好意思,你办不到.苹果不允许.因为你没有权限.
- sql常识-like
LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式. LIKE 操作符 LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式. SQL LIKE 操作符语法 SELECT colum ...
- 使用WDS安装Windows8.1
WDS的部署 安装角色 配置 1. 选择配置服务器 2. 核对是否满足要求 3. 输入远程安装文件夹的路径 4. 选择是否使用自带的DHCP服务器 5. 可以保持默认 6. 完成配置后添加映像文件 7 ...
- jquery 评论等级(很差,差,一般,好,很好)代码
可能标题没有说的太明白,这里先让大家看一下效果,以便让客官们了解小弟说的是什么... 看完效果后估计各位客官已经明白小弟说的是什么了吧,下面小弟就带大家看下代码 <style> .maxd ...
- ASP.NET MVC 之控制器与视图之间的数据传递
今天,我们来谈谈控制器与视图之间的数据传递. 数据传递,指的是视图与控制器之间的交互,包括两个方向上的数据交互,一个是把控制器的数据传到视图中,在视图中如何显示数据,一个是把视图数据传递到控制器中, ...