PG中文社区 /

为何使用 Postgres

原作者:Craig Kerstiens  创作时间:2017-12-14 00:39:06+08
doudou586 发布于2017-12-18 00:39:06           评论: 3   浏览: 169602   顶: 60221  踩: 60898 

作者:Craig Kerstiens

翻译:PostgreSQL中文社区 / doudou586

发布:2017-12-14

欢迎大家踊跃投稿,投稿信箱: press@postgres.cn


五年以前,我写了一个《为何你应使用PostgreSQL》的岾子,引起了广泛的关注。一年以后,我增加了一些我漏写的内容,这些内容我会在这篇文章的后半部分重述一下要点。但是在最近的4-5年,PostgreSQL有了很多的改进和提高,也就有了更多的理由我们为何要使用它。现在这里是一个新的总结,为何你应使用PostgreSQL这一忒棒的数据库。

PostgreSQL_WhyUsePG_01

数据类型,包括JSONB和范围(Range)类型

Postgres一直以来对新增数据类型都是开放和友好的系统。 它有数组、空间地理以及很多时间相关的数据类型。几年前它又增加了两种值得我们关注和使用的新类型:

JSONB 类型

JSONB 是一个二进制的JSON数据类型。它可以使用GIN 和 GIST格式进行索引。你也可以快速查询完整的JSON 文档。

Range 范围类型

这个数据类型现在还没有JSONB有名,范围类型当它是你需要的类型时,它才会特别地有用。 对时间范围来说,使用一列字段来表达从一个值到另一个值的范围特别方便。如果你创建一个日历应用,或者总是有一个从哪个时间到另一个时间的参数,那范围类型可以让你只需使用一个字段值即可。更大的好处还有你可以指定一定的时间范围不能相互覆盖、交叉,或是其他对你的应用有用的约束。

Extensions扩展功能

谈到Postgres就很难不提到围绕它存在的生态系统。扩展模块的使用对社区来说很关键,同时也促使Postgres快速发展。扩展使用户可以让用户使用原生的系统连接Postgres核心,而不必是将需求提交给Postgres的核心开发。这也意谓着用户可以增加丰富的功能而不必与Postgres内核的发布和审核循环连在一起。一些特别有名的重磅扩展有:

Citus扩展

Citus (这也是我工作的内容) 扩展让Postgres成为了一个分布式数据库,它允许用户很容易地将数据库进行跨节点的分发。 而对你的应用来说,它仍然像是一个单节点的数据库,而在后台,Citus会将数据传给多个不同的物理设备和多个Postgres的实例。

HyperLogLog扩展

这是一个我个人最为喜欢的扩展,它允许用户对大量数据的聚集的唯一计数有一个很容易获得且非常接接近理论值的结果,当然也可以对跨时间联合、相交等各种操作进行 处理。HyperLogLog和其他的概要逻辑对处理大数据集和分布式数据库很常用,并且是可以很方便地嵌入Postgres内部使用。

PostGIS扩展

PostGIS不是一个新的扩展,但它是一个值得重提亮点。它通常都是被认为是最先进的地理数据库。PostGIS增加了新的高级的地理空间数据类型、操作符,使得很多与位置有关的地图类或是路由类的操作变得很容易。

逻辑复制

多年以来,大家要求最多的就是解决Postgres中设置数据复制的易用性。最早时我们也有基本的复制方案,然后我们有了流复制技术(即二进制的WAL或称之为预写日志)。 对类似wal-e这样的工具,帮助提升了Postgres在灾难恢复方面的能力。

现在最近的版本里,我们有了逻辑复制,虽然现在还是需要一个扩展,不是100%内核功能,但最终我们还是有了一个完整的逻辑复制方案。逻辑复制允许用户发送不同数量的指令,这也意谓着我们可以复制指定的内容或表。

系统扩展性

除了我们见到的Postgres在持续对功能和性能的改进,最近也是特别地增加了并行查询功能以获取更好的性能。如果用户需要超出单个Postgres节点的扩展,我们可以使用前面提到的Citus进行横向扩展。

丰富的索引

Postgres现在有很多种强大的索引,像GIN 和GiST索引,它们对JSONB数据特别有用。我们现在也有了KNN 和Sp-GiST索引格式,并且还在增加中。

Upsert功能

Upsert在Progress已开发和演变有好几年了。当然,一些用户可以通过变通使用CTE功能来实现类似功能,但可能会产生一些条件冲突。这个特性曾是MySQL有但Postgres没有的功能,现在1年多前,Postgres也有了正式的支持。

外部数据源封装

当然,还有几年前就有的外部数据源封装功能。它允许你映射外部数据系统至Postgres中的表。这就意谓着,比如,我们可以在Postgres中查询Redis的数据库。这项功能5年前就一直在不断地改进和提高,尤其是现在我们已支持可写的外部数据源处理,即我们在Postgres直接写入数据至外部数据库。现在官方的Postgres发布版本中至少带有Postgres的FDW,它对跨Postgres实例读写数据尤其有用。

更多其他的功能

如果你对以前的PG版本不是太熟,在以前的版本中一些应了解的功能还包括:

  • 窗口函数
  • 一般函数
  • 可定制的语言
  • NoSQL 数据类型
  • 定制函数
  • CTE表达式
  • 并行索引创建
  • 事务DDL
  • 外部数据封装
  • 条件或函数式索引
  • 事件侦听/提醒
  • 表继承
  • 事务级的同步复制

PostgreSQL_Community


评论:3   浏览: 169602                   顶: 60221  踩: 60898 

请在登录后发表评论,否则无法保存。

1# __ xcvxcvsdf 回答于 2024-11-27 01:49:57+08
http://gx.lztcxxw.cn/gansu/ http://shenghuo.china-bbs.com/hnsmx/ http://jinqiang.ahtcbmw.cn/chuzhou/ http://huaguang.jxtcbmw.cn/hnzz/ http://yz.cqtcxxw.cn/xiangtan/ https://fenlei.tiancebbs.cn/hangzhou/ https://mohe.tiancebbs.cn/ https://hechengzhen.tiancebbs.cn/ https://zhijiang.tiancebbs.cn/ https://enshishi.tiancebbs.cn/ http://wogao.ahtcbmw.cn/jiayuguan/ http://ly.shtcxxw.cn/xianyang/ http://nalei.zjtcbmw.cn/shannan/ http://nalei.zjtcbmw.cn/jjq/ https://fenlei.tiancebbs.cn/ycfw/ https://yangma.tiancebbs.cn/ http://ruanwen.xztcxxw.cn/tangshan/

2# __ xcvxcvsdf 回答于 2024-10-29 22:18:12+08
https://nancheng.tiancebbs.cn/ http://nalei.zjtcbmw.cn/hnzmd/ http://huaguang.jxtcbmw.cn/fangchanxinwen/ http://js.sytcxxw.cn/scab/ https://songshan.tiancebbs.cn/ http://taiying.njtcbmw.cn/zcrsy/ http://km.lstcxxw.cn/hechi/ http://ouyu.hftcbmw.cn/hbxn/ http://gx.lztcxxw.cn/hljhrb/ https://yongshun.tiancebbs.cn/ http://cf.lstcxxw.cn/shluwan/ http://ruanwen.xztcxxw.cn/suzhou/ https://fenlei.tiancebbs.cn/hnzzs/ http://ruanwen.xztcxxw.cn/sxsz/ http://cf.lstcxxw.cn/jining/ https://yiliang.tiancebbs.cn/ http://jingren.hftcbmw.cn/yongzhou/

3# __ xiaowu 回答于 2024-04-22 09:44:16+08
西游记读后感:https://www.nanss.com/xuexi/2754.html 土地租赁合同:https://www.nanss.com/shenghuo/3220.html 笑一笑没什么大不了:https://www.nanss.com/yuedu/3963.html 金工实习报告:https://www.nanss.com/gongzuo/3337.html 宣传部工作总结:https://www.nanss.com/gongzuo/2547.html 朋友圈晒花的唯美句子:https://www.nanss.com/wenan/4009.html 应急预案:https://www.nanss.com/gongzuo/3121.html 红楼梦读书笔记:https://www.nanss.com/yuedu/3277.html 舞蹈队名字有创意好听:https://www.nanss.com/mingcheng/3552.html 我的梦想英语作文:https://www.nanss.com/xuexi/3297.html 有趣网名:https://www.nanss.com/mingcheng/3870.html 一晃孩子长大了的句子:https://www.nanss.com/yulu/4010.html 女生甜美网名:https://www.nanss.com/mingcheng/3805.html 关于爱情的qq网名:https://www.nanss.com/mingcheng/3813.html 党员转正申请书:https://www.nanss.com/xuexi/2671.html 暗示人品差的句子:https://www.nanss.com/yulu/2523.html 繁体游戏名字:https://www.nanss.com/mingcheng/3605.html 我的老师作文:https://www.nanss.com/xuexi/2852.html 可爱的游戏名:https://www.nanss.com/mingcheng/3743.html 女人发抖音最火的句子:https://www.nanss.com/wenan/3964.html 个性群名:https://www.nanss.com/mingcheng/3949.html qq霸气名字:https://www.nanss.com/mingcheng/3564.html 什么像什么一样什么比喻句二年级:https://www.nanss.com/xuexi/3761.html 芮怎么读拼音:https://www.nanss.com/xuexi/3792.html 格林童话:https://www.nanss.com/yuedu/3122.html 游什么作文400字四年级:https://www.nanss.com/xuexi/3098.html 团结就是力量作文:https://www.nanss.com/xuexi/3270.html 生日短句:https://www.nanss.com/yulu/3889.html 旷课检讨书:https://www.nanss.com/xuexi/3238.html 苦难辉煌读后感:https://www.nanss.com/xuexi/3133.html



发表评论:
加入我们
QQ群1:5276420
QQ群2:3336901
QQ群3:254622631
文档群:150657323
文档翻译平台:按此访问
社区邮件列表:按此订阅
扫码关注
© PostgreSQL中文社区 ... (自2010年起)