Oracle中的wmsys.wm_concat
来源:互联网 发布:cad网络信息点图标 编辑:程序博客网 时间:2024/05/17 08:16
引用:http://blog.sina.com.cn/s/blog_03c54d100101abqd.html
Oracle中的wmsys.wm_concat主要实现行转列功能(说白了就是将查询的某一列值使用逗号进行隔开拼接,成为一条数据)。
wmsys.wm_concat除了单独使用外还可以和over函数结合使用。
开始看看具体使用方法:
select t.rank, t.Name from t_menu_item t;
上边的查询语句返回的结果可以清晰看到rank存在重复的,一个相同的rank对应多个Name,如果我们想把某一个Rank的所有Name以","隔开,怎么做的,当然可以自定义函数,
别急,Oracle 10g开始提供了这个wmsys.wm_concat,它可以帮助我们把行的值以逗号隔开,看看怎么来实现.
一。直接使用wmsys.wm_concat
select t.rank, WMSYS.WM_CONCAT(t.Name) TIME From t_menu_item t GROUP BY t.rank;
通过Group by进行分组,查询每类Rank对应的Name的值,看看查询的结果.
是不是很神奇,rank已经分类,并且他的Name已经用逗号进行隔开。
二.wmsys.wm_concat和over的结合使用
over函数:over函数指定了分析函数工作的数据窗口的大小,这个数据窗口大小可能会随着行的变化而变化。
例如:
over(order by salary)按照salary排序进行累计,order by是个默认的开窗函数;
over(partition by deptno) 按照部门分区;
over(order by salaryrange between 50 preceding and 150 following)每行对应的数据窗口是之前行幅度值不超过50,之后行幅度值不超过150的数据记录 ;
over(order by salary rows between 50 perceding and 150 following)前50行,后150行;
over(order by salary rows between unbounded preceding and unbounded following)所有行 ;
over(order by salary range between unbounded preceding and unbounded following)所有行。
看看wmsys.wm_concathe和over的结合例子:
select id,wmsys.wm_concat(name) over (order by id,name) name from idtable;
根据id,name进行排序累计,看看输出的结果.
id name
10 ab
10 ab,bc
10 ab,bc,cd
20 ab,bc,cd,hi
20 ab,bc,cd,hi,ij
20 ab,bc,cd,hi,ij,mnke
可以清晰的看到id为10的name列的值是从ab依次叠加到最后ab,bc,cd(当然这几个值肯定是id为10对应的值),id为20的name列的值是从ab,bc,cd,hi(之所以不是从ab开始是因为当前order by的
还有name列,所以需要继续向下进行)一直到ab,bc,cd,hi,ij,mnke.
select id,wmsys.wm_concat(name) over (partition by id) name from idtable;
这个例子仅仅是根据id进行排序(over (order by ename)如果没有order by 子句,求和就不是“连续”的,这个就是和上个实例的最大区别,没有连续)。
ID NAME
10 ab,bc,cd
10 ab,bc,cd
10 ab,bc,cd
20 hi,ij,mn
20 hi,ij,mn
20 hi,ij,mn
可以看到仅仅是根据id进行排序的查询。
select id,wmsys.wm_concat(name) over (partition by id,name) name from idtable;
ID NAME
10 ab
10 bc
10 cd
20 hi
20 ij
20 mn
可以看到,这里和上个实例的区别在于Name列没有叠加,因为在over 中加入了name
- Oracle中的wmsys.wm_concat
- Oracle中的wmsys.wm_concat
- Oracle中的wmsys.wm_concat
- Oracle中的wmsys.wm_concat
- oracle中的wmsys.wm_concat()函数
- oracle wmsys.wm_concat函数
- oracle wmsys.wm_concat用法
- oracle之wmsys.wm_concat
- 关于oracle中的wmsys.wm_concat中的使用问题
- 关于oracle中的wmsys.wm_concat中的使用问题
- 破解Oracle函数"wmsys.wm_concat()"
- oracle 内部函数 wmsys.wm_concat
- 执行Oracle中的函数wm_concat报错oracle wmsys.wm_concat ORA-00932: 数据类型不一致: 应为 -, 但却获得 CLOB
- wmsys.wm_concat
- wmsys.wm_concat
- wmsys.wm_concat
- wmsys.wm_concat
- oracle 的wmsys.wm_concat函数用法
- HDOJ 1165 Eddy's research II(数学)
- POJ 动态规划题目列表
- oracle 安装过程中的问题
- Linux init程序分析(续)
- ios_oc @property和@synthesize以及属性介绍
- Oracle中的wmsys.wm_concat
- Android 创建快捷方式图标
- X Window System介绍
- C++子类 父类的相互转换 和 虚函数
- JMF网页视频语音聊天
- 极速理解设计模式系列:2.工厂方法模式(Factory Method Pattern)
- 【Visual Studio】VS2012中利用Visual Assist X添加文件头和函数注释
- 拷贝构造函数
- 微信公众平台SDK! Senparc.Weixin.MP.dll(资料整理)