当前位置: 首页 > news >正文

ORACLE行记录转字符串用分隔符连接的两个函数:WM_CONCAT、LISTAGG

WM_CONCAT 是 Oracle 数据库中一个非官方的聚合函数(属于 Oracle 内部函数,未正式文档正式支持),用于将多行数据的某一列值拼接成一个字符串,通常用逗号分隔。

基本语法

WM_CONCAT(列名)
  • 作用:将分组内指定列的多行值拼接为一个字符串(默认用逗号分隔)。
  • 适用场景:需要将多行数据合并为单行展示时(如“一行显示某个部门的所有员工姓名”)。

示例

假设有表 EMP 如下:

DEPTNO ENAME
10 CLARK
10 KING
10 MILLER
20 SMITH
20 JONES

使用 WM_CONCAT 按部门拼接员工姓名:

SELECT DEPTNO,WM_CONCAT(ENAME) AS DEPT_EMPLOYEES
FROM EMP
GROUP BY DEPTNO;

结果:

DEPTNO DEPT_EMPLOYEES
10 CLARK,KING,MILLER
20 SMITH,JONES

注意事项

  1. 非官方函数,兼容性差
    WM_CONCAT 并非 Oracle 官方推荐的函数,在 Oracle 12c 及以上版本中已被移除(或隐藏),可能导致“标识符无效”错误。不建议在生产环境使用

  2. 替代方案:LISTAGG(官方推荐)
    Oracle 11g 及以上版本提供了官方支持的 LISTAGG 函数,功能更强大且稳定,语法如下:

    -- 基本用法(默认逗号分隔)
    SELECT DEPTNO,LISTAGG(ENAME, ',') WITHIN GROUP (ORDER BY ENAME) AS DEPT_EMPLOYEES
    FROM EMP
    GROUP BY DEPTNO;
    
    • LISTAGG(列名, 分隔符):指定拼接的列和分隔符。
    • WITHIN GROUP (ORDER BY ...):可选,指定拼接时的排序规则。
  3. 结果类型限制
    WM_CONCAT 返回值类型为 VARCHAR2CLOB(取决于拼接后长度),若拼接结果过长可能报错。LISTAGG 也有长度限制(默认 VARCHAR2(4000)),超过时可结合 ON OVERFLOW TRUNCATE 处理(12c+ 支持)。

  4. 大小写问题
    部分环境中 WM_CONCAT 可能需要大写(WM_CONCAT),否则报错,因 Oracle 对未加引号的标识符默认转为大写。

总结

WM_CONCAT 可临时用于低版本 Oracle(11g 及以下)的字符串拼接,但因其非官方性和兼容性问题,推荐优先使用官方函数 LISTAGG,避免升级数据库后出现兼容性问题。

http://www.jsqmd.com/news/41279/

相关文章:

  • MySQL 8+ 日志管理与数据备份恢复实战指南 - 指南
  • 航运、应急、工业适用,AORO P1100三防平板引领行业数字化变革 - 详解
  • 20232419 2025-2026-1 《网络与系统攻防技术》实验五实验报告
  • 为什么高手写 CSS 都偏爱 rem?这三大优势无法拒绝
  • 完整教程:FPGA 49 ,Xilinx Vivado 软件术语解析(Vivado 界面常用英文字段详解,以及实际应用场景和注意事项 )
  • 前端css中rem的作用
  • 第三十天
  • WinDbg 随笔 001 —— HelloWorld + WinDbg
  • 数据结构2:单链表 - 教程
  • 20251115 - Hash 总结
  • BZOJ2372 music
  • P11664 [JOI 2025 Final] 缆车 / Mi Telefrico
  • WPF中RelayCommand的完成与使用详解
  • C++篇(14)二叉树进阶算法题 - 详解
  • Python 潮流周刊#127:Python 3.16 JIT 性能提升计划
  • 非线性序列密码结构
  • 2025/11/15
  • LoongOS 上传文件
  • 基础设施即服务(IaaS)全面解析:云计算的基石
  • CentOS 7 通过 Packstack 安装 OpenStack Train 完整步骤
  • 【STM32工程开源】基于STM32的人体健康监测环境
  • 实用指南:【C# OOP 入门到精通】从基础概念到 MVC 实战(含 SOLID 原则与完整代码)
  • tailwind自定义class问题小记
  • 2025年主流开源AI智能体框架平台概览 - 实践
  • threading.local()的实例化机制
  • Tarjan复建
  • 采用git进行项目管理
  • Golang游戏开发笔记:地图索引系统实现
  • 20251115
  • 网络爬虫:简单静/动态网页