发布说明

PostgreSQL 15.13

E.5. 发布版本 15.13 #

发布日期:. 2025-05-08

本次发布包含来自 15.12 的多项修复。 有关 15 主版本新特性的说明,请参见 Section E.18

E.5.1. 迁移到版本 15.13 #

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

但是,如果你在分区表上有自引用外键约束,可能需要重新创建这些约束, 以确保这些约束能够被正确强制执行。请参见下面的第二条变更日志条目。

此外,如果你有任何 BRIN bloom 索引,建议在更新后对其进行重建索引。 请参见下面的第三条变更日志条目。

此外,如果你从早于 15.9 的版本升级,请参见 Section E.9

E.5.2. 变更 #

  • 避免在检查声称为 GB18030 编码的无效编码字符串时发生单字节缓冲区越界读取 (Noah Misch,Andres Freund) § §

    虽然不太可能发生,但如果不完整的多字节字符出现在内存末尾,可能会导致 SIGSEGV 崩溃。 这在服务器和使用 libpq 的应用程序中都可能发生。 (CVE-2025-4207)

  • 正确处理分区表上的自引用外键 (Álvaro Herrera) §

    创建或附加分区时,如果外键约束引用的表是同一分区表本身,则未能创建所需的系统目录条目。 这导致该约束无法被完整强制执行。

    要修复此问题,如果在创建该约束之后曾创建或附加过分区, 你应删除并重新创建分区表上的所有自引用外键。请注意,可能已经存在违反约束的行; 在这种情况下,重新创建约束会失败,你需要先修正这些行,然后再试一次。

  • 避免在 brin_bloom_union() 中合并压缩的 BRIN 摘要时丢失数据 (Tomas Vondra) §

    代码未能考虑到解压缩结果与输入对象不完全相同的情况,这会导致部分数据未能被添加到 合并后的摘要中,从而在索引搜索中遗漏行。

    这个错误早在引入 BRIN bloom 索引的 v14 版本中就已存在,但当时这一代码路径很少被触发。 在 v17 中由于并行索引构建使用了该代码,触发的可能性大大增加。

  • 修复在 UPDATEDELETEMERGE 查询中使用 FROM 中引用视图或函数的整行表引用时出现的意外 attribute has wrong type 错误 (Tom Lane) § § §

  • 修复对带有 DO NOTHING 动作的分区表执行 MERGE 的问题 (Tender Wang) §

    某些情况会出现 unknown action in MERGE WHEN clause 错误。

  • 防止当表具有域数据类型的 GENERATED 列且该域的约束不允许空值时, INSERT 命令出现失败 (Jian He) §

    即使生成表达式产生了完全正常的结果,也会报告约束失败。

  • 正确处理附加到 INSERT/UPDATE/DELETE/MERGE 命令的 WITH 子句中出现的对外部 CTE 名称的引用, 该命令本身位于 WITH 内部 (Tom Lane) §

    解析器未能检测到不允许的递归情况,也未在将 CTE 排序为可用顺序时考虑此类引用。

  • 修复 ARRAY(subquery)ARRAY[expression, ...] 构造,使其在输入类型为 int2vectoroidvector 时 产生合理的结果(Tom Lane) §

    此补丁恢复了 PostgreSQL 9.5 之前的行为: 结果类型为 int2vector[]oidvector[]

  • 修复在解析 Ispell 字典时可能错误报告无效词缀的问题 (Jacob Brazeal) §

  • 修复 ALTER TABLE ADD COLUMN 以正确处理具有默认值的域类型的情况 (Jian He,Tom Lane,Tender Wang) § §

    如果域类型具有默认值,在不使用显式 DEFAULT 子句的情况下添加该类型的列,未能在现有行中安装域的默认值, 而是将新列留为空值。

  • 修复外键约束的 ON DELETE SET DEFAULTSET NULL 动作中存在重复列名时的异常行为 (Tom Lane) §

  • 改进对不允许的外键约束属性修改尝试的错误消息 (Álvaro Herrera) §

  • 避免在重置标记为 ON COMMIT DELETE ROWS 的临时表的 relhassubclass 标志时出错 (Noah Misch) §

  • 修复规划器未能在顶层表达式中识别多个可哈希的 ScalarArrayOpExpr 子表达式的问题 (David Geier) §

    这导致本可以用哈希表处理的附加子表达式(即右侧全为常量的 INNOT IN= ANY 子句)被不必要地低效执行。

  • 禁用位图堆扫描中的跳过获取优化 (Matthias van de Meent) §

    事实证明,当并发 vacuum 将页面标记为全部可见时,此优化可能导致返回死元组。

  • 修复当搜索键很多时 GIN 索引搜索启动的性能问题 (Tom Lane,Vinod Sridharan) § §

    具有大量键的可索引子句(例如,具有数万个数组元素的 jsonbcol ?| array[...])启动时需要 O(N2) 的时间,并且在此期间也无法取消。

  • 检测 BRIN 索引操作符类中缺少的支持过程,并报告错误而不是崩溃 (Álvaro Herrera) §

  • 在等待 Append 计划节点的异步子计划时响应中断(如查询取消) (Heikki Linnakangas) §

    之前,在某个子计划就绪之前不会发生任何响应。

  • 修复启动后立即处理 synchronous_standby_names 时的竞态条件 (Melnikov Maksim,Michael Paquier) §

    在系统启动后的短暂时间内,即使启用了 synchronous_standby_names,后端也可能未能等待同步提交。

  • 修复 pg_strtof() 在 endptr 为空时崩溃的问题 (Alexander Lakhin,Tom Lane) §

  • 避免 Snowball 词干提取器在遇到内存不足情况时崩溃 (Maksim Korotkov) §

  • 防止逻辑解码快速前进模式中 catalog xmin 的过度推进 (Zhijie Hou) §

    这个错误可能允许已删除的系统目录条目被 vacuum 清除, 即使 WAL 读取进程仍可能需要它们。

  • 避免在不取强锁的 DDL 操作影响正在进行逻辑复制的表时发生数据丢失 (Shlok Kyal,Hayato Kuroda) § §

    DDL 命令引起的系统目录变更未能反映到 WAL 解码进程中, 使其可能使用过时的系统目录数据解码后续变更,可能导致数据损坏。

  • 避免在逻辑复制索引查找中重复创建快照 (Heikki Linnakangas) § §

  • 修复关于不正确恢复时间线选择的错误消息中的检查点详情错误 (David Steele) §

    如果请求的恢复时间线不可达,报告的检查点和时间线应该是从 backup_label 中读取的值(如果有的话)。之前此消息报告的是控制文件中的值, 这在没有 backup_label 从控制文件恢复时是正确的,但在有 backup_label 时则不正确。

  • 修复快照构建中的断言失败 (Masahiko Sawada) §

  • 移除 pgstat_report_stat() 中不正确的断言 (Michael Paquier) §

  • 修复 gistFindCorrectParent() 中过于严格的断言 (Heikki Linnakangas) §

  • 修复主库重启时备库中罕见的断言失败 (Heikki Linnakangas) §

  • 在 PL/pgSQL 中,避免在可滚动游标定义在简单的 SELECT expression 查询上时出现 unexpected plan node type 错误 (Andrei Lepikhov) §

  • pg_dump--clean 模式中不要尝试删除单独的索引分区 (Jian He) §

    服务器会拒绝这样的 DROP 命令。这并没有实际影响, 因为分区在后续对其父表或分区索引的 DROP 操作中会自动消失。 但是,尝试删除时报告的错误在以 --single-transaction 模式恢复时会导致问题。

  • pg_dumpall 中,如果 pg_auth_members 包含无效的角色 OID,避免生成无效的角色 GRANT 命令 (Tom Lane) §

    改为打印警告并跳过该条目。这能更好地处理在旧版本分支中由于 GRANTDROP ROLE 之间的竞态条件而导致的系统目录损坏。

  • pg_amcheckpg_upgrade 中,使用正确的函数 来释放由 libpq 分配的内存 (Michael Paquier,Ranier Vilela) §

    这些疏忽可能导致在某些 Windows 构建配置中崩溃,例如 libpq 的调试构建被非调试构建的调用应用程序使用。

  • 允许通过查询取消来中断 contrib/dblink 查询 (Noah Misch) § §

    此变更回迁了 v17 时代的修复。它防止了由于未能检测到死锁而导致的 CREATE DATABASEDROP DATABASE 可能挂起的情况。

  • 避免 contrib/pageinspectheap_page_items() 在输入数据损坏时崩溃 (Dmitry Kovalenko) §

  • 防止 contrib/pg_freespacemappg_freespacemap() 中的断言失败 (Tender Wang) §

    pg_freespacemap() 应用于没有存储的关系(如视图) 会导致断言失败,但在非断言构建中没有不良影响。 增加了错误检查以拒绝这种情况。

  • 修复在 macOS 15.4 上的构建失败 (Tom Lane,Peter Eisentraut) §

    此 macOS 更新破坏了我们对 strchrnul() 的配置探测。

  • 将时区数据文件更新到 tzdata 版本 2025b,包含智利的夏令时法律变更以及伊朗的历史修正 (Tom Lane) §

    新增了时区 America/Coyhaique,用于智利的艾森大区, 因为该地区已改为全年使用 UTC-03,从而与 America/Santiago 分离。