<p style="text-align: center;"><img alt="" src="https://simg.open-open.com/show/377f2065335f19932cfac918c3abe56b.jpg" /></p> <p>目前非常流行的RDBMS <a href="/misc/goto?guid=4959012109466175318" rel="nofollow,noindex">PostgresSQL</a> 已经在几周前发布了它的 <a href="/misc/goto?guid=4959011215987424864" rel="nofollow,noindex">第10个版本</a> 。由于Postgres的可靠性、节约成本、成熟,当然还有它的开源,已经21岁的Postgres在开发者之中仍旧非常流行。</p> <p>Postgres 10带来了一些新特性,其中一些特性另开发者感到十分兴奋。 <a href="/misc/goto?guid=4959012109659635623" rel="nofollow,noindex">10Clouds</a> 在 <a href="/misc/goto?guid=4959012109815106513" rel="nofollow,noindex">博客</a> 中详细介绍了其中的一些特性。通过消除主表(master table)中触发器(trigger)的需求,本地分区(native partitioning)现在变得更简单了。这意味着创建分区表将变得更简单,并且从开发者的角度来看,现在从分区数据表中进行查询和插入与在非分区的数据表进行这些操作是完全一致的。</p> <p>多列统计(multicolumn statistics)是Postgres 10的另一项改进。通过把来自不同列的数据关联起来,查询规划器(query planner)现在可以避免一些边缘情况,在那些边缘情况下,之前的Postgres版本会 <a href="/misc/goto?guid=4959012109932839041" rel="nofollow,noindex">认为</a> WHERE语句 <a href="/misc/goto?guid=4959012110028570482" rel="nofollow,noindex">更强的选择性</a> ,并且会导致选择了错误计划从而拖慢执行时间。Postgres的这个改进在整个SQL世界中都是极具创新性的。</p> <p>Postgres 10还对 <a href="/misc/goto?guid=4959012110129400762" rel="nofollow,noindex">并行性</a> 进行了改进。开发者现在可以使用索引扫描(index scans)和仅索引扫描(index-only scans)、并行合并连接(merge joint)以及位图堆扫描。并行查询是通过不同的workers来实现的,因此在某些情况下,设置和分解的成本会超过并行化的好处。默认情况下,可以在大于8MB大小的表以及大于512KB的索引上启用并行表扫描(parallel table scan),但是这些选项可以根据需要进行配置。</p> <p>Postgres 10另一个重要的新特性是支持JSON和JSONB类型列的 <a href="/misc/goto?guid=4959012110276720956" rel="nofollow,noindex">全文搜索</a> 。一旦我们创建了一个特定语言的全文索引,我们就可以通过JSON字段对值进行直接搜索。在JSON列上的全文索引与其他列是类似的,因此我们的查询需要使用to_tsquery函数和to_tsvector函数的文本搜索的语法。</p> <p><a href="/misc/goto?guid=4959012110395811135" rel="nofollow,noindex">标识列(Identity columns)</a> 和自增列(Auto-increment columns)也是Postgres 10进行改进的一个地方。新的实现方法会有一点冗长,但是它是符合SQL标准的,使得在不同数据库之间的迁移会更加容易。最重要的是,使用Postgres 10时,我们在从一个不同的id重启时,不再需要修改序列(alter sequences)了,但是我们可以对这一列进行修改(alter),Postgres就会将这一列识别为一个序列,这样操作会简化我们数据库中的日常操作。</p> <p>正如我们预料到的那样,Postgres 10存在一些 <a href="/misc/goto?guid=4959012110488753999" rel="nofollow,noindex">不向后兼容</a> 的改动。对浮点时间戳的支持已经被抛弃了,对于低于版本8的 pg_dump也已经不再提供支持,有关复制(replication)和pg_basebackup工具的一些默认值也有所变化。版本编号由三部分改为了两部分,同时开发者的脚本不能直接运行,而是使用类似于 <a href="/misc/goto?guid=4959012110593946021" rel="nofollow,noindex">server_version_num</a> 这种查询,它返回的是一致的的可排序的和可比较的(sortable and comparable)版本号。</p> <p>来自: http://www.infoq.com/cn/news/2017/12/Postgres-10-Features-Developers</p>