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

【ORACLE】listagg() 函数

Oracle 数据库中的 LISTAGG 函数是一个聚合函数,它用于将多个行的字符串值合并成一个单一的字符串。这对于生成报告或创建列表非常有用,例如,将同一类别的所有项合并成一个逗号分隔的字符串。

语法

LISTAGG(expression, delimiter) WITHIN GROUP (ORDER BY column)
  • expression:要聚合的字符串表达式。
  • delimiter:用于分隔合并后的字符串值的分隔符。
  • column:用于排序聚合字符串的列。

选项

  • WITHIN GROUP:这是必需的,用于指定聚合操作的分组方式。
  • ORDER BY:这是可选的,用于在聚合之前对行进行排序。

溢出处理

  • ON OVERFLOW:这是可选的,用于指定当结果超过最大长度限制时如何处理溢出。常见的选项有:
    • TRUNCATE:截断结果,不包括最后一个分隔符。
    • ERROR:如果结果超过最大长度,抛出错误。
    • NULL:如果结果超过最大长度,返回 NULL。

示例

假设有一个名为 employees 的表,其中包含员工的名字(name)和部门(department)。

  1. 基本聚合

    SELECT department, LISTAGG(name, ', ') WITHIN GROUP (ORDER BY name) AS department_names
    FROM employees
    GROUP BY department;
    

    这个查询将返回每个部门的员工名字列表,名字按字母顺序排列,用逗号和空格分隔。

  2. 处理溢出

    SELECT department, LISTAGG(name, ', ') WITHIN GROUP (ORDER BY name) 
    ON OVERFLOW TRUNCATE AS department_names
    FROM employees
    GROUP BY department;
    

    如果聚合后的字符串超过了 Oracle 的最大长度限制(默认为 4000 字符),则结果将被截断。

  3. 不排序

    SELECT department, LISTAGG(name, ', ') WITHIN GROUP (ORDER BY name) AS department_names
    FROM employees
    GROUP BY department;
    

    如果不使用 ORDER BY 子句,聚合的顺序将不确定。

  4. 包含 NULL 值

    LISTAGG 默认会忽略 NULL 值。如果你想在结果中包含 NULL 值,可以使用 NULLIF 函数来转换 NULL 值为一个特定的字符串。

    SELECT department, LISTAGG(NULLIF(name, 'NULL'), ', ') WITHIN GROUP (ORDER BY name) AS department_names
    FROM employees
    GROUP BY department;
    

    在这个例子中,如果 name 是 NULL,它将被替换为字符串 ‘NULL’。

LISTAGG 函数是 Oracle 中处理字符串聚合的强大工具,可以帮助你创建复杂的报告和列表。

相关文章:

  • 第4章 汇编语言和汇编软件
  • JAVA vs Python:谁更适合后端开发?
  • 使用C++编写接口调用PyTorch模型,并生成DLL供.NET使用
  • UFUG2601-OJ 2048 Game
  • SpringMVC 第一次复学笔记
  • AI智能电销机器人的优势是什么,有什么特点?
  • vscode使用
  • 【Postgresql】地理空间数据的存储与查询,
  • 速盾:防御ddos攻击的几大有效方法是什么?
  • 笔记:应用Visual Studio Profiler分析CPU使用情况
  • 4、Django Admin对自定义的计算字段进行排序
  • 论tomcat线程池和spring封装的线程池
  • 第二章 数据访问:JPA
  • 探索Ansible自动化运维:提高效率的关键工具
  • zabbix和prometheus介绍;云原生
  • 数据结构之 “单链表“
  • 2d像素游戏基本架构
  • C++ 容器迭代器失效
  • 前端算法面试题1--栈、队列、链表、字典与哈希表
  • 操作系统-第二章【上】
  • 解放日报社论:只争朝夕、不负重托,加快建成具有全球影响力的科技创新高地
  • 15世纪以来中国文化如何向欧洲传播?《东学西传文献集成初编》发布
  • 病人有头发,照护者不发疯:《黑镜》中的身体缺席与虚伪关怀
  • 我国将开展市场准入壁垒清理整治行动
  • 王星昊再胜连笑,夺得中国围棋天元赛冠军
  • 找化学的答案,解人类的命题:巴斯夫的“变革者”成长之道