`
二师兄hit
  • 浏览: 4232 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
社区版块
存档分类
最新评论

wm_concat与listagg

阅读更多

连接字符串
1.wm_concat
2.listagg

案例:
/*拆分regexp_substr 合并wm_concat 替换regexp_replace*/
WITH a AS
 (SELECT '1,a,1,b,2,a,2,c,3,d,3,e,4,y' a FROM dual)
SELECT b, wm_concat(c) d
  FROM (SELECT regexp_substr(a, '[^,]+', 2 * LEVEL - 1, LEVEL) b,
               regexp_substr(a, '[^,]+', 2 * LEVEL, LEVEL) c
          FROM a
        CONNECT BY LEVEL <
                   (length(a) - length(regexp_replace(a, '[^,]+', '')) + 1) / 2)
 GROUP BY b;

/*拆分regexp_substr 合并listagg 替换regexp_replace*/
WITH a AS
 (SELECT '1,a,1,b,2,a,2,c,3,d,3,e,4,y' a FROM dual)
SELECT b, listagg(c,',') within GROUP(ORDER BY b) d
  FROM (SELECT regexp_substr(a, '[^,]+', 2 * LEVEL - 1, LEVEL) b,
               regexp_substr(a, '[^,]+', 2 * LEVEL, LEVEL) c
          FROM a
        CONNECT BY LEVEL <
                   (length(a) - length(regexp_replace(a, '[^,]+', '')) + 1) / 2)
 GROUP BY b;
 
/*wm_concat*/
WITH a AS
 (SELECT 1 id, 'a' NAME
    FROM dual
  UNION ALL
  SELECT 1 id, 'b' NAME
    FROM dual
  UNION ALL
  SELECT 1 id, 'c' NAME
    FROM dual
  UNION ALL
  SELECT 2 id, 'b' NAME
    FROM dual
  UNION ALL
  SELECT 2 id, 'a' NAME
    FROM dual
  UNION ALL
  SELECT 3 id, 'c' NAME
    FROM dual
  UNION ALL
  SELECT 3 id, 'd' NAME
    FROM dual
  UNION ALL
  SELECT 4 id, 'b' NAME
    FROM dual)
SELECT id, wm_concat(NAME) NAME FROM a GROUP BY id;

/*不用group by 使用over(PARTITION BY XXX)*/
WITH temp AS
 (SELECT 500 population, 'China' nation, 'Guangzhou' city
    FROM dual
  UNION ALL
  SELECT 1500 population, 'China' nation, 'Shanghai' city
    FROM dual
  UNION ALL
  SELECT 500 population, 'China' nation, 'Beijing' city
    FROM dual
  UNION ALL
  SELECT 1000 population, 'USA' nation, 'New York' city
    FROM dual
  UNION ALL
  SELECT 500 population, 'USA' nation, 'Bostom' city
    FROM dual
  UNION ALL
  SELECT 500 population, 'Japan' nation, 'Tokyo' city
    FROM dual)
SELECT population,
       nation,
       city,
       listagg(city, ',') within GROUP(ORDER BY city) over(PARTITION BY nation) rank
  FROM temp

分享到:
评论

相关推荐

    wm_concat函数所需资源包

    在Oracle数据库环境中,`WM_CONCAT`函数是一个非常实用的工具,用于将多个行的数据合并成单个字符串。然而,自Oracle 11g R2版本开始,这个函数被标记为弃用,导致许多用户在使用时遇到问题。标题中的"wm_concat函数...

    ORA-00904: "WM_CONCAT": 标识符无效

    如果压缩包中的文件是自定义函数,那么在你的环境中部署这个函数后,你就可以继续使用与WM_CONCAT类似的功能,但要注意,这种方法可能会影响性能,因此在生产环境中使用前需要进行充分的测试。 总之,面对"ORA-...

    重建WMSYS用户的WMSYS.WM_CONCAT函数的3个文件

    WMSYS schema包含了所有与这些功能相关的表、视图和存储过程,其中就包括WM_CONCAT函数。 2. **WMSYS.WM_CONCAT函数**: WM_CONCAT是一个非标准的Oracle函数,它能将多个字符串合并成一个单一的字符串,用分隔符...

    wm_concat函数DDL.zip

    在Oracle数据库中,`wm_concat`函数曾是一个非常实用的工具,用于将多个行的数据合并成单个字符串,尤其在需要进行数据汇总时非常方便。然而,从Oracle 11g版本开始,出于性能和安全性的考虑,Oracle官方取消了这个...

    ORA-00904 WMSYS.WM_CONCAT标识符无效解决方案

    综上所述,解决"ORA-00904 WMSYS.WM_CONCAT标识符无效"的问题,主要是通过转向Oracle提供的新功能如LISTAGG,或者自定义合适的聚合函数来完成。提供的压缩包文件可能是为了解决这个问题而设计的,具体使用方法应参照...

    解决Oracle没有WM_CONCAT函数.zip

    在Oracle数据库中,WM_CONCAT是一个非常实用的聚合函数,用于将一组字符串连接成一个单一的字符串,类似于SQL Server中的STRING_AGG或MySQL中的GROUP_CONCAT。然而,Oracle官方并没有提供这个函数,它是一个第三方...

    12C开始_wm_concat函数.sql

    Oracle从12C版本开始,不支持wm_concat函数,我们可以采取的办法有使用listagg函数代替wm_concat函数,或者为了减小修改程序的工作量,可以通过手工创建wm_concat函数来解决这个问题。

    WM_CONCAT.zip

    `WM_CONCAT`的替代方案是使用`LISTAGG`函数,这是Oracle 11g引入的一个新特性,它可以将行集中的数据聚合为单个字符串,同时支持分隔符。例如,如果你有一个包含产品ID的表,你可以用`LISTAGG`来生成一个逗号分隔的...

    Oracle重建WMSYS用户及WMSYS.WM_CONCAT函数(更低分)

    在Oracle中,若需要替换`WM_CONCAT`功能,可以使用`LISTAGG`函数(从11g版本开始提供),它更为强大且标准,支持分组内的字符串聚合。例如: ```sql SELECT LISTAGG(column_name, ', ') WITHIN GROUP (ORDER BY ...

    自写函数用于替换wm_concat函数.zip

    总之,"自写函数用于替换wm_concat函数.zip"提供的解决方案旨在帮助Oracle数据库用户在不支持`WM_CONCAT`的环境中实现行数据的合并,利用`LISTAGG`等内置函数,提供了灵活且高效的数据处理方式。对于那些依赖`WM_...

    BLOG_Oracle_wm_concat包的订制.pdf

    【Oracle_wm_concat包的订制】 在Oracle数据库中,`WM_CONCAT`函数曾经是一个非常实用的工具,尤其在处理行转列的问题时。然而,这个函数在Oracle 12c及更高版本中被废弃,因为其存在一些不稳定性和性能问题。在10G...

    oracle合并列的函数wm_concat的使用详解

    Oracle推荐使用`LISTAGG`函数来替代`WM_CONCAT`,`LISTAGG`提供了更强大且标准的字符串聚合功能,同时也支持排序等高级特性。 例如,使用`LISTAGG`函数达到同样的效果: ```sql SELECT u_id, LISTAGG(goods || ' ...

    Oracle重建WMSYS用户及WMSYS.WM_CONCAT函数

    WM_CONCAT函数在早期的Oracle版本中是一个实用的聚合函数,用于将多个字符串合并为一个,但在较新的版本中已被DEPRECATED(弃用),并由其他函数如LISTAGG取代。 解决这个问题的方法是重建WMSYS用户下的相关包,这...

    Oracle10g自定义聚合函数(字符串拼接)

    * 自定义聚合函数 wmsys.wm_concat 替换办法 * 超大字符串拼接,单个字符串4000、分隔符100,可拼出超4000的超长字符串 * 可自定义指定分隔符separator * 可自定义指定排序字段sequence,对于数字或日期类型的...

    oracle wm_concat 列转行 逗号分隔

    然而,由于WM_CONCAT的局限性,Oracle建议使用其他替代方法,如使用LISTAGG函数(自Oracle 11g R2起提供)或者自定义聚合函数来实现类似的功能。LISTAGG函数提供了更好的控制,比如可以指定分隔符,并且是标准的SQL...

    oracle实现行转列功能,并使用逗号进行隔开拼接,成为一条数据.pdf

    Oracle 实现行转列功能并使用逗号...使用 WM_CONCAT 函数或 LISTAGG 函数可以实现 Oracle 中的行转列功能,并使用逗号进行隔开拼接,成为一条数据。然而,需要注意 WM_CONCAT 函数已经被弃用,建议使用 LISTAGG 函数。

    oracle—SQL技巧之(二)WMSYS.WM_CONCAT函数实现多行记录用逗号拼接在一起

    在Oracle数据库中,有时我们需要将多行记录合并成一个单一的字符串,以便于...不过,需要注意的是,从Oracle 11g R2版本开始,推荐使用`LISTAGG`函数代替`WM_CONCAT`,因为它更稳定,且支持更复杂的分组和排序操作。

    OracleWMSYS.rar

    1. **WM_CONCAT 函数已弃用**:在较新的 Oracle 版本中,WM_CONCAT 被标记为已弃用,建议使用其他字符串连接方法,如 concatenation(||)操作符或 LISTAGG 函数。 2. **权限问题**:你可能没有足够的权限去执行 ...

Global site tag (gtag.js) - Google Analytics