PostgreSQL 12 Beta 1 版本新特性预览

PostgreSQL 12 Beta 1 版本新特性预览,第1张

概述文章目录索引相关的性能、功能和管理内联 WITH 查询(通用表表达式)分区增强遵循 SQL/JSON 规范的 JSON 路径查询排序规则最频繁值统计计算列可插拔式表存储接口页面校验和认证与连接安全变更注意事项2019-05-23 PostgreSQL 全球开发组发布消息称,PostgreSQL 12 第一个 beta 版提供下载测试。这个版本包含了 PostgreSQL 12 正式版中的所有特性...

文章目录 索引相关的性能、功能和管理内联 WITH 查询(通用表表达式)分区增强遵循 SQL/JSON 规范的 JSON 路径查询排序规则最频繁值统计计算列可插拔式表存储接口页面校验和认证与连接安全变更注意事项

2019-05-23 Postgresql 全球开发组发布消息称,Postgresql 12 第一个 beta 版提供下载测试。这个版本包含了 Postgresql 12 正式版中的所有特性预览,不过某些细节可能存在变数。最终的 Postgresql 12 正式版将会在 2019 年下半年发布。

随之发布的包括 Postgresql 12 最新特性,以下是其中一部分。

索引相关的性能、功能和管理

Postgresql 12 改进了标准 B-树索引的整体性能以及索引的磁盘空间管理。这些改进还减少了频繁修改的B-树索引占用的空间大小。

此外,Postgresql 12 新增了并发重建索引的功能,使得执行REINDEX *** 作时不会阻塞索引的写入。这一特性可以解决生产环境中长时间的索引重建导致的停机问题。

Postgresql 12 扩展了某些特殊索引的功能。Postgresql 11 引入了覆盖索引,即INCLUDE子句,现在该功能可以支持 GiST 索引。SP-GiST 索引现在针对支持距离 *** 作(<->)的数据类型提供了K-近邻(K-NN)查询功能。

Postgresql 12 明显减少了创建 GiST、GIN 或者 SP-GiST 索引产生的预写式日志(WAL),为 Postgresql 集群的磁盘利用率和其他特性(例如连续归档和流复制)带来了诸多改进。

内联 WITH 查询(通用表表达式)

通用表表达式(即WITH查询)如果满足以下所有条件,将会被自动内联到查询语句中:

非递归无副作用只被引用一次

这一特性消除了自 Postgresql 8.4 引入WITH子句以来一直存在的优化障碍(optimization fence)。

如果有需要,你还可以使用MATERIAliZED子句强制WITH查询物化,例如:

WITH c AS MATERIAliZED (  SELECT * FROM a WHERE a.x % 4 = 0  )SELECT * FROM c   JOIN d ON d.y = a.x;
分区增强

Postgresql 12 改进了访问包含数千分区的表中少量分区时的性能。

Postgresql 12 还提高了分区表的INSERTcopY *** 作的性能。ATTACH PARTITION现在不会阻塞分区表上的并发查询。另外, Postgresql 12 支持引用分区表的外键。

遵循 sql/JsON 规范的 JsON 路径查询

Postgresql 12 支持 sql:2016 标准中 sql/JsON 规定的 JSON 路径查询。与 XML 查询中的 XPath 表达式类似,JsON 路径表达式使得查询 JsON 文档时,除了可以使用值进行比较之外,还可以使用各种算术表达式和函数。

某些表达式可以用于提供 GIN 索引的性能,实现跨 JsON 数据集的高性能查找。

排序规则

Postgresql 12 支持 ICU 排序规则的大小写不敏感(case-insensitive)和重音不敏感(accent-insensitive)的比较方式,即“不确定性排序规则”。使用这些方式时,可以为比较和排序 *** 作提供便捷,但是也可能导致性能下降,因为需要对字符串执行额外的检查。

最频繁值统计

Postgresql 10 引入了 CREATE STATISTICS,用于收集多个字段上的复杂统计信息,以便改进查询计划。现在,该语句支持最频繁值统计。这一功能改进了非均匀分布值上的查询计划。

计算列

Postgresql 12 支持创建计算列(generated columns),也就是基于其他列计算出该列的值。该特性目前支持存储计算列(stored generated columns),即在插入和更新时进行计算并且将结果保存到磁盘上。不过,暂时还没有实现虚拟计算列(virtual generated columns),也就是在查询执行时直接计算出该列的值。

可插拔式表存储接口

Postgresql 12 引入了可插拔式的表存储接口,运行创建和使用不同的表存储方式。这一特性类似于 MysqL 的插件式存储引擎。可以通过 CREATE ACCESS METHOD 命令添为 Postgresql 集群添加新的访问方法,然后在创建表的CREATE table语句中使用新的USING子句为其指定访问方法。

通过创建一个新的表访问方法可以定义一个表存储接口。

在 Postgresql 12 中,默认使用的存储接口为 heap 访问方法,这也是目前唯一内置的访问方法。

页面校验和

pg_verify_checkums命令被重命名为 pg_checksums,并且支持启用和禁用离线 Postgresql 集群的页面校验和功能。在此之前,页面校验和只能在使用 initdb 初始化集群时被启用。

认证与连接安全

GSSAPI 支持客户端和服务器的加密,可以在文件 pg_hba.conf 中使用 记录类型 hostgssenc 和 hostnogssenc 进行配置。如果使用了 OpenLDAP 编译选项,Postgresql 12 还支持基于 DNS SRV 记录的 LDAP 服务器发现功能。

变更注意事项

Postgresql 12 引入的某些变更可能会影响现有系统的的行为。下面给出了一些这种变更;更多的信息可以参考发行说明中的“迁移到 Postgresql 12”。

配置文件 recovery.conf 被合并到主配置文件 postgresql.conf 中。Postgresql 如果检测到 recovery.conf,将不会启动。如果想要将 Postgresql 设置为非主模式,可以使用 recovery.signal 和 standby.signal 两个文件。

可以通过以下链接查看更多关于归档恢复的内容:

https://www.postgresql.org/docs/devel/runtime-config-wal.html#RUNTIME-CONFIG-WAL-ARCHIVE-RECOVERY

即时编译(JIT)功能默认被启用Just-in-Time (JIT) 。用户使用WITH OIDs子句创建的表中不再添加 OID 字段。针对这些使用WITH OIDS创建的字段(即名为“OID”的字段)上执行的 *** 作需要进行调整

针对系统表执行的SELECT *命令现在会显示 OID 信息,而不需要像之前一样明确指定该字段的名称。

除此之外,Postgresql 12 还提供了许多重要的新特性和增强功能,完整的新特性列表可以参考 PostgreSQL 12 发行说明。

总结

以上是内存溢出为你收集整理的PostgreSQL 12 Beta 1 版本新特性预览全部内容,希望文章能够帮你解决PostgreSQL 12 Beta 1 版本新特性预览所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1150483.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存