PostgreSQL 的 vacuum
进程对于系统健康运行至关重要,且需要服务器实例资源。PostgreSQL 17 引入了一种新的 vacuum 内部内存结构,将内存消耗降低了多达 20 倍。这不仅提高了 vacuum 的速度,还减少了共享资源的占用,为您的工作负载释放了更多资源。
PostgreSQL 17 继续提升其 I/O 层的性能。由于对预写日志(WAL)处理的改进,高并发工作负载的 写入吞吐量可能提升至 2 倍。此外,新的流式 I/O 接口加快了顺序扫描(读取表中所有数据)以及 ANALYZE
更新查询计划统计信息的速度。
PostgreSQL 17 也在查询执行方面提升了性能。对于使用 B-tree 索引(PostgreSQL 默认的索引方法)的 IN
子句查询,性能有所提高。此外,BRIN 索引现在支持并行构建。PostgreSQL 17 在查询规划方面进行了多项改进,包括对 NOT NULL
约束的优化,以及对公用表表达式(WITH
查询)处理的改进。本次发布还为加速计算添加了更多 SIMD(单指令多数据)支持,包括在 bit_count
函数中使用 AVX-512。
进一步丰富的开发者体验
PostgreSQL 是首个添加 JSON 支持的关系型数据库(2012 年),PostgreSQL 17 进一步完善了其对 SQL/JSON 标准的实现。JSON_TABLE
现已在 PostgreSQL 17 中可用,允许开发者将 JSON 数据转换为标准的 PostgreSQL 表。PostgreSQL 17 现在支持 SQL/JSON 的构造函数(JSON
、JSON_SCALAR
、JSON_SERIALIZE
)和查询函数(JSON_EXISTS
、JSON_QUERY
、JSON_VALUE
),为开发者提供了与 JSON 数据交互的更多方式。本次发布添加了更多 jsonpath
表达式,重点是将 JSON 数据转换为原生的 PostgreSQL 数据类型,包括数值、布尔值、字符串和日期/时间类型。
PostgreSQL 17 为 MERGE
添加了更多特性,用于条件更新,包括 RETURNING
子句和更新视图的能力。此外,PostgreSQL 17 为批量加载和数据导出提供了新功能,包括在使用 COPY
命令导出大型行时性能提升多达 2 倍。当源和目标编码匹配时,COPY
性能也有所提升,并包含一个新选项 ON_ERROR
,允许在插入错误时继续导入。
此次发布还扩展了对分区数据和分布在远程 PostgreSQL 实例上的数据的管理功能。PostgreSQL 17 支持在分区表上使用标识列和排除约束。用于在远程 PostgreSQL 实例上执行查询的 PostgreSQL 外部数据包装器(postgres_fdw
)现在可以将 EXISTS
和 IN
子查询下推到远程服务器,以实现更高效的处理。
PostgreSQL 17 还包含一个内置的、平台无关的、不可变的排序规则提供者,确保排序规则的不可变性,并提供了类似于 C 排序规则的排序语义,但使用 UTF-8 编码而非 SQL_ASCII。使用这个新的排序规则提供者,可以保证您的文本查询无论在何处运行 PostgreSQL,都能返回相同的排序结果。