发布日期:. 2025-05-08
本次发布包含来自 14.17 的多项修复。 有关 14 主版本新特性的说明,请参见 Section E.23。
对于运行 14.X 的用户,不需要执行导出/恢复。
但是,如果分区表上存在自引用外键约束,可能需要重新创建这些约束,以确保它们得到正确执行。请参见下面的第二个变更日志条目。
此外,如果存在任何 BRIN bloom 索引,建议在更新后重建这些索引。请参见下面的第三个变更日志条目。
此外,如果是从早于 14.14 的版本升级,请参见 Section E.9。
避免在检查声称为 GB18030 编码的无效编码字符串时发生单字节缓冲区越界读取 (Noah Misch,Andres Freund) § §
虽然可能性不大,但如果不完整的多字节字符出现在内存末尾,可能会导致 SIGSEGV 崩溃。这在服务器和使用 libpq 的应用程序中都可能发生。 (CVE-2025-4207)
正确处理分区表上的自引用外键 (Álvaro Herrera) §
创建或附加分区时未能为外键约束创建所需的目录条目,如果该约束引用的表就是同一个分区表。这会导致该约束无法被完全执行。
要修复此问题,如果在约束创建之后曾创建或附加过分区,则应删除并重新创建分区表上的任何自引用外键。请注意,可能已经存在违反约束的行,在这种情况下重新创建约束会失败,你需要先修复这些行后再重试。
避免在 brin_bloom_union() 中合并压缩的 BRIN 摘要时丢失数据 (Tomas Vondra) §
该代码未能考虑到解压缩结果与输入对象不完全相同的情况,这会导致未能将部分数据添加到合并后的摘要中,从而在索引搜索中遗漏行。
这个错误从引入 BRIN bloom 索引的 v14 就存在了,但当时这个代码路径很少被触及。在 v17 中由于并行索引构建现在使用了该代码,因此更容易被触发。
修复在 UPDATE、DELETE 和 MERGE 查询中使用对视图或函数的整行表引用(在 FROM 中)时出现的意外 “attribute has wrong type” 错误 (Tom Lane) § § §
防止当表具有域数据类型的 GENERATED 列且该域的约束不允许空值时 INSERT 命令失败的问题 (Jian He) §
即使生成表达式产生了完全正常的结果,仍会报告约束违反错误。
正确处理出现在附加到 INSERT/UPDATE/DELETE/MERGE 命令(该命令本身在 WITH 内部)的 WITH 子句中对外部 CTE 名称的引用 (Tom Lane) §
解析器未能检测到不允许的递归情况,也未能在将 CTE 排列为可用顺序时考虑此类引用。
修复 ARRAY( 和 subquery)ARRAY[ 构造,使其在输入类型为 expression, ...]int2vector 或 oidvector 时产生合理的结果 (Tom Lane) §
此补丁恢复了 PostgreSQL 9.5 之前的行为:结果类型为 int2vector[] 或 oidvector[]。
修复解析 Ispell 字典时可能错误报告无效词缀的问题 (Jacob Brazeal) §
修复 ALTER TABLE ADD COLUMN 以正确处理具有默认值的域类型的情况 (Jian He,Tom Lane,Tender Wang) § §
如果域类型具有默认值,在不带显式 DEFAULT 子句的情况下添加该类型的列,未能在现有行中安装域的默认值,而是将新列保留为空值。
改进对不允许的外键约束属性修改尝试的错误消息 (Álvaro Herrera) §
避免在重置标记为 ON COMMIT DELETE ROWS 的临时表的 relhassubclass 标志时出错 (Noah Misch) §
修复规划器在顶层表达式中无法识别多个可哈希的 ScalarArrayOpExpr 子表达式的问题 (David Geier) §
这导致了本可以用哈希表处理的额外子表达式(即右侧全为常量的 IN、NOT 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) §
在归档恢复期间跳过 WAL 回收和预分配,以避免损坏从归档恢复的 WAL 文件 (Noah Misch,Arun Thirupathi) § § § § § § §
此变更回移了 v15 时代的修复,当时被认为大致是修饰性的,但事实证明能防止后续修复引起的数据损坏。
防止在逻辑解码的“快进”模式中过度推进 catalog xmin (Zhijie Hou) §
这个错误可能导致已删除的目录条目被清理掉,即使 WAL 读取进程仍可能需要它们。
避免在不需要强锁的 DDL 操作影响正在进行逻辑复制的表时丢失数据 (Shlok Kyal,Hayato Kuroda) § §
DDL 命令导致的目录变更未被反映到 WAL 解码进程中,使其可能使用过期的目录数据解码后续变更,很可能导致数据损坏。
修复快照构建中的断言失败 (Masahiko Sawada) §
修复 gistFindCorrectParent() 中过于严格的断言 (Heikki Linnakangas) §
修复当主库重启时备库中罕见的断言失败 (Heikki Linnakangas) §
在 PL/pgSQL 中,避免当可滚动游标定义在简单 SELECT 查询上时出现 “unexpected plan node type” 错误 (Andrei Lepikhov) §expression
在 pg_dump 的 --clean 模式中不再尝试删除单个索引分区 (Jian He) §
服务器会拒绝这样的 DROP 命令。这实际上没有什么影响,因为这些分区在后续对其父表或分区索引执行 DROP 时会被自动删除。但是,尝试删除时报告的错误会在以 --single-transaction 模式恢复时造成问题。
在 pg_dumpall 中,避免在 pg_auth_members 包含无效角色 OID 时生成无效的角色 GRANT 命令 (Tom Lane) §
改为打印警告并跳过该条目。这能更好地处理在后端分支中因 GRANT 和 DROP ROLE 之间的竞态条件而导致的目录损坏。
在 pg_amcheck 和 pg_upgrade 中,使用正确的函数释放由 libpq 分配的内存 (Michael Paquier,Ranier Vilela) §
这些疏忽可能导致在某些 Windows 构建配置下崩溃,例如调试版本的 libpq 被非调试版本的调用程序使用时。
允许 contrib/dblink 查询被查询取消中断 (Noah Misch) § §
此变更回移了 v17 时代的修复。它防止了由于未能检测到死锁而导致 CREATE DATABASE 和 DROP DATABASE 可能挂起的问题。
避免在 contrib/pageinspect 的 heap_page_items() 中因损坏的输入数据而崩溃 (Dmitry Kovalenko) §
防止 contrib/pg_freespacemap 的 pg_freespacemap() 中的断言失败 (Tender Wang) §
对没有存储的关系(如视图)应用 pg_freespacemap() 会导致断言失败,尽管在非断言构建中没有不良影响。增加了错误检查以拒绝这种情况。
修复在 macOS 15.4 上的构建失败 (Tom Lane,Peter Eisentraut) §
此 macOS 更新破坏了我们对 strchrnul() 的配置探测。
更新时区数据文件至 tzdata 2025b 版本,包含智利的夏令时法律变更以及伊朗的历史修正 (Tom Lane) §
新增时区 America/Coyhaique 用于智利的 Aysén 大区,以反映其改为全年使用 UTC-03,从而与 America/Santiago 产生差异。