wm_concat

wm_concat(column):此函数实现字段合并,可以把列值以","号分隔起来并显示成一行,实现行转列的效果。

例如:表shopping:

-----------------------------------------

u_id       goods            num

-----------------------------------------

1               苹果               2

2               梨子               5

1               西瓜               4

3               葡萄               1

3               香蕉               1

1               橘子               3

-----------------------------------------

想要的结果为:

u_id          goods_sum

-----------------------------------------

1              苹果(2斤),西瓜(4斤),橘子(3斤)

2              梨子(5斤)

3              葡萄(1斤),香蕉(1斤)

时间: 2025-01-22 19:54:35

wm_concat的相关文章

ORA-22922: 不存在的 LOB 值 可以使用外层嵌套wm_concat()解决

select kw0408id, sjbh, ksrs, kch, to_char(wm_concat(kcmc)) as kcmc, ksxs, kssc, ksfs, kcxz, xsyx, nj from (select a.kw0408id, a.sjbh, a.ksrs, kch, kcmc, to_char(wm_concat(distinct KSXS.DMMC)) as ksxs, to_char(wm_concat(distinct kssjcd.dmmc)) as kssc,

WM_CONCAT字符超过4000的处理办法

在进行使用WM_CONCAT或者自定义的聚合函数,进行拼串的时候,可能遇到拼串形成的结果集大于4000,这时候,系统会提示,超过系统限制.所以,在这个时候,最好的处理办法就是将结果集处理成CLOB格式, 下面共有两种处理方式: 1.使用函数 类型: create or replace type str2tblType as table of varchar2(4000) 函数: CREATE OR REPLACE FUNCTION tab2clob(p_str2tbltype str2tblty

重写Oracle的wm_concat函数,自定义分隔符、排序

oracle中,wm_concat函数是一个聚合函数,和mysql中的group_concat函数类似,不过group_concat函数比较强大,可以定义分隔符和排序,当然所谓强大是相对的,这里假使我们不知道oracle中的over函数,也不知道listagg函数. 我们先来看看wm_concat函数能实现什么功能,通俗点==>列传行,如果不明白,请看下面截图(可以看到分隔符默认为','顺序也是杂乱的)          所以,接下来,我们开始重写wm_concat函数(需要注意和需要说明的地方

oracle wm_concat(column)函数的使用

oracle wm_concat(column)函数使我们经常会使用到的,下面就教您如何使用oracle wm_concat(column)函数实现字段合并,如果您对oracle wm_concat(column)函数使用方面感兴趣的话,不妨一看. shopping: ----------------------------------------- u_id       goods            num -----------------------------------------

Oracle数据库合并行记录,WMSYS.WM_CONCAT 函數的用法

Sql代码 select t.rank, t.Name from t_menu_item t; 10 CLARK    10 KING    10 MILLER    20 ADAMS    20 FORD    20 JONES    20 SCOTT    20 SMITH    30 ALLEN    30 BLAKE    30 JAMES    30 MARTIN    30 TURNER    30 WARD -------------------------------- 我们通过

多列转1列 SqlServer 实现oracle10g的 wmsys.wm_concat()--for xml path('')

有这么一个表 create table tb(id int, value varchar(10)) insert into tb values(1, 'aa') insert into tb values(1, 'bb') insert into tb values(2, 'aaa') insert into tb values(2, 'bbb') insert into tb values(2, 'ccc') insert into tb values(3, 'ddd') insert int

oracle的wm_concat函数实现行转列

有以下数据 deptname phone username isboss 部门A 电话1 员工A 0 部门A 电话1 领导A 1 部门B 电话2 员工B 0 部门B 电话2 员工C 0 部门B 电话2 领导D 1 需要展示效果 deptname phone boss emp 部门A 电话1 领导A 员工A 部门B 电话2 领导D 员工B,员工C 因为是oracle10g的原因,所以使用了wm_concat函数,但对wm_concat结果长度有限制,超出会报ORA-22922:不存在的LOB值,这

wm_concat函数

wm_concat函数 wm_concat函数 一般分类 — 作者 zzy020128 @ 12:21 首先让我们来看看这个神奇的函数wm_concat(列名),该函数可以把列值以","号分隔起来,并显示成一行,接下来上例子,看看这个神奇的函数如何应用 准备测试数据 SQL> create table test(id number,name varchar2(20)); SQL> insert into test values(1,'a'); SQL> insert

listagg( ) within group ( order by ) 与 wm_concat

listagg( ) within group ( order by ) 与 wm_concat --oracle 11g 及以后适合 最好 select spbywslid,listagg(xm,',') within group (order by spbywslid) col_name from tpg_jtcyqk group by spbywslid; --oracle 10g 及以前版本用 select spbywslid,wm_concat(xm)xm from tpg_jtcyq

2015.12.24(圣诞节) 解决Oralce数据库将具有相同属性的多行合并为一行的简单方法多年想要wmsys.wm_concat

用到Oralce10g以后增加的函数wmsys.wm_concat 例如这张表的有两个字段,要按airport_id合并成两行可用sql语句 select airport_id,   wmsys.wm_concat( account) from AIRPORT_MODIFY group by airport_id 结果为: 非常简单,美中不足的是合并结果没有排序,解决排序问题最简单的办法就是在合并列前加上distinct 此外,如果合并列结果出现乱码,需要在合并列前加上to_char(),如wm