发布说明

PostgreSQL 18.3

E.1. 发布版本 18.3 #

发布日期:. 2026-02-26

本次发布包含来自 18.2 的少量修复。 有关 18 主版本新特性的说明,请参见 Section E.4

E.1.1. 迁移到版本 18.3 #

对于运行 18.X 的用户,不需要执行导出/恢复。

但是,如果你从早于 18.2 的版本升级,请参见 Section E.2

E.1.2. 变更 #

  • 修复在重放由较旧小版本生成的 WAL 多事务 ID 截断记录后发生失败的问题 (Heikki Linnakangas) §

    为兼容旧版本处理多事务 ID 回卷方式而编写的错误逻辑,会导致重放失败,并出现诸如 could not access status of transaction 之类的消息。 一种典型场景是:最新小版本的备库正在消费来自较旧版本主库的 WAL。

  • 避免在将 substring() 应用于 toasted 数据时 错误报告无效编码(Noah Misch) § § §

    针对 CVE-2026-2006 的修复过于激进,在实际上有效的场景中也可能报出字符不完整错误。

  • 修复针对 CVE-2026-2007 的修复中遗漏的问题(Zsolt Parragi) §

    如果因为输入包含的 trigram 比初始估计更多而需要扩展 bounds 数组, generate_trgm_only 没有把修改后的数组指针返回给调用者。 这会导致 strict_word_similarity() 及相关函数输出错误, 极少数情况下还会崩溃。只有当输入字符串在转换为小写后变长时才会触发这段错误代码。 目前已知仅会在某些单字节编码配合 ICU locale 时发生这种情况。

  • 修复 json_strip_nulls()jsonb_strip_nulls() 的波动性标记 (Andrew Dunstan) §

    这些函数一直被视为不可变,但在版本 18 的重构中却意外被标记为稳定。 这会阻止它们被用于索引表达式,并可能导致查询中不必要的重复求值。 该修复会纠正在新初始化的数据库集簇中的标记 (包括通过 pg_upgrade 升级到 18.3 或更高版本的集簇)。 但是,它无法帮助使用 18.0 到 18.2 创建的现有集簇。

    如果这一错误影响到了你对这些函数的使用,建议对现有集簇执行手工目录更新。 以超级用户身份在每个受影响的数据库中执行:

    UPDATE pg_catalog.pg_proc SET provolatile = 'i' WHERE oid IN ('3261','3262');
    

    同时也要更新 template0template1, 这样将来新建的数据库也会带有该修复。

  • 修复对 LATERAL UNION ALL 子查询输出中可能置空的外连接集合的计算 (Richard Guo) §

    这一错误可能导致系统误以为某些 NOT NULL 测试没有必要,从而跳过它们, 最终产生错误的查询结果。

  • 避免用户自定义约束与自动命名的 NOT NULL 约束发生名称冲突 (Laurenz Albe) §

    从版本 18 开始,NOT NULL 约束拥有完整的 pg_constraint 条目,因此需要名字。 对未命名 NOT NULL 约束选择名称的逻辑,未能避免与同一 CREATE TABLE 语句中用户编写的其他约束发生冲突。

  • 修复 pg_stat_get_backend_wait_event()pg_stat_get_backend_wait_event_type(), 使其能够报告辅助进程的值(Heikki Linnakangas) §

    之前这些函数对辅助进程会返回 NULL,但这与 pg_stat_activity 视图的行为不一致。

  • 修复在从 PL/pgSQL 函数返回其值时,将复合类型变量转换为域类型的问题 (Tom Lane) §

    如果该变量的值为 NULL,则会出现 cache lookup failed for type 0 错误。

  • 修复 contrib/hstore 二进制输入函数中潜在的空指针解引用问题 (Michael Paquier) §

    hstore 的接收函数在输入包含重复键时会崩溃。 由 Postgres 生成的 hstore 值永远不会包含重复键,因此这一错误一直未被发现。 恶意或损坏的数据都可能触发该崩溃。