如果不是领导强制要求,可能根本不会留意到这款号称世界上功能最强大的开源数据库——PostgreSQL。如果你不读这篇文章,或许也会错过一个跃跃欲试想挤进前三的优秀数据库。

为了能够熟练运用,特意买书研究,发现这款数据库还真有点意思。汇总一篇文章与大家分享,目的只有一个:让大家多少了解一下这款数据库。

你会发现与Mysql相比,PostgreSQL的社区并不活跃,中文资料可以说是少得可怜,在数据库中排行老四。前三都不一定全用过,谁会去记住老四呢。但下面的数据不得不让我们留意。

下面是DB-Engines数据库流行度排行榜2020年7月份的数据。

在老大老二的评分不断下降的情况下,这么一个没有后台的开源数据库,竟然励精图治,突飞猛进。有没有像春秋战国时的秦国,是时候得留意一下它了。

下面再看看这几年PostgreSQL的增速情况。

图中遥遥领先其他数据库,追赶前三名的数据库,就是PostgreSQL,不少大厂已经在使用了。

PostgreSQL是一款开源的对象关系型数据库,也就是说与Mysql的功能一致。在欧美地区使用比较广泛,因其限制严格、实现严谨,在金融、电信等领域应用比较多。

对照Mysql来了解一下PostgreSQL(以下简称PG):

1、在SQL的标准实现上比MySQL完善,而且功能实现比较严谨;

2、存储过程的功能支持要比MySQL好,具备本地缓存执行计划的能力;

3、PG对表连接支持较完整,优化器的功能较完整,支持的索引类型很多,复杂查询能力较强;

4、PG主表采用堆表存放,MySQL采用索引组织表,能够支持比MySQL更大的数据量。

5、PG的主备复制属于物理复制,相对于MySQL基于binlog的逻辑复制,数据的一致性更加可靠,复制性能更高,对主机性能的影响也更小。

6、MySQL的存储引擎插件化机制,存在锁机制复杂影响并发的问题,而PG不存在。

上面是比较笼统的概述,下面给大家汇总一下读相关书籍发现。

1、数据库、表等操作基本相同,与Mysql不同的是PG的主键自增采用了独立的序列,然后将序列赋值给对应的字段来实现自增。

2、PG的字段级、表级的约束也特别有意思。可以通过CHECK关键字来约束指定字段是否大于或小于某个阈值(仅举例,不限于此)。针对表级别的约束,还可以通过CHECK关键字来约束两个字段之间的关系,比如:CHECK(createtime < parentcreatetime)。是不是非常有意思?

3、数据类型中PG提供了money类型,可基于时区来显示对应的货币格式,如“$1,000.00”。

4、数据类型中支持了丰富的日期时间类型,而还有相应的运算操作,加减乘除应有尽有。

5、数据类型中还支持了点、线、线段、矩形、路径、多边形、圆等几何图形,虽然不会经常用到,有便是一件很Cool的事。当然,也少不了JSON和数组的类型。

6、PG提供了数学函数、字符串函数、二进制字符串函数、数据类型格式化函数、日期和时间函数、位串函数、枚举函数、几何函数、JSON函数、范围函数、数字函数等等,丰富到眼花缭乱。

7、SQL查询中提供了递归查询,内置了大量的窗口函数。

8、索引支持B-tree索引、Hash索引、GiST索引、SP-GiST索引、GIN索引、BRIN索引。足够丰富。

9、视图支持物化视图和普通视图。

10、支持表继承,面向对象编程的朋友是不是对此很亲切。

11、PG支持基本的表分区功能更,PG10之后支持声明式内置表分区功能。该功能支持把大表拆分成更小的物理分片,分别进行独立存储。

12、PG支持在大型事务中通过使用保存点(SAVEPOINT)来回滚部分事务。

13、PG对SQL语句进行了逻辑优化和物理优化。

当然,还有其他很多有意思的功能等待发掘。读完上述内容你是不是也有兴趣了解一下?那这篇文章的目的就达到了。

最后,写这篇文章有两个目的。第一,很明确,给大家介绍一款数据库。第二,是想推广一个学习提升的理念:尽情去去尝试了解新事物,努力突破自己的舒适区,这往往会给自己带来非常大的收获。

世界上最强大的开源数据库,你了解多少呢?相关推荐

  1. 你了解世界上功能最强大的开源数据库吗?

    如果不是领导强制要求,可能根本不会留意到这款号称世界上功能最强大的开源数据库--PostgreSQL.如果你不读这篇文章,或许也会错过一个跃跃欲试想挤进前三的优秀数据库. 为了能够熟练运用,特意买书研 ...

  2. 世界上功能最强大的开源数据库-PostgreSQL

    转载自:https://www.lzfkj.vip/post/22 文章目录 简述 PostgreSQL 特性 安装 源码安装 安装后所常见到的错误 1.提示相关命令不存在 2.提示连接不了数据库 3 ...

  3. uniapp无法使用substr_SQLite 3.34.0发布,世界上使用量最大的数据库引擎

    点击"蓝字"关注我们吧 SQLite 3.34.0 发布了,SQLite 是一个 C 实现的 SQL 数据库引擎,它的特点是小型.快速.自包含.高可靠性和功能齐全.SQLite 嵌 ...

  4. SQLite 3.31.0 发布,世界上使用量最大的数据库引擎

    SQLite 是一个 C 实现的 SQL 数据库引擎,它的特点是小型.快速.自包含.高可靠性和功能齐全.SQLite 嵌入在所有手机和大多数计算机中,也捆绑在为数众多的其它应用中,是世界上使用量最大的 ...

  5. SQLite 3.30.0 发布,世界上使用量最大的数据库引擎

    SQLite 3.30.0 发布了,SQLite 是一个 C 实现的 SQL 数据库引擎,它的特点是小型.快速.自包含.高可靠性和功能齐全.SQLite 嵌入在所有手机和大多数计算机中,也捆绑在为数众 ...

  6. 世界上最强大的两个字母的单词

    Morpheus向Leo提供红色药丸和蓝色药丸-版权所有华纳兄弟公司. 这个词代表了指导宇宙和所有生命的因果定律. 这是一个很小的词,它本身不执行任何操作,但完全由其上下文定义. 没有两个单词比IF单 ...

  7. 三个字母的单词颠倒也是单词_世界上最强大的两个字母的单词

    三个字母的单词颠倒也是单词 Morpheus向Leo提供红色药丸和蓝色药丸-版权所有华纳兄弟公司. 这个词代表了指导宇宙和所有生命的因果定律. 这是一个很小的词,它本身不执行任何操作,但完全由其上下文 ...

  8. 世界上最强大的SoC——NVIDIA Xavier学习笔记

    界上最强大的SoC--NVIDIA Xavier学习笔记 NVIDIA在2018年CES上推出了Xavier平台,作为Driver PX2 的进化版本.NVIDIA称Xavier 是"世界上 ...

  9. 苹果推出新Mac Pro:配备28个核处理器及世界上最强大的显卡

    十次方消息,近日,苹果在位于加利福尼亚州圣何塞的全球开发者大会(WWDC)上发布了一款新的Mac Pro.它将于今年秋季上市,售价为5,999美元.首发配置包括8核Xeon处理器,32GB内存,Rad ...

最新文章

  1. SCOM2012部署系列之七:推送Windows监控代理
  2. 时间复杂度O(n),空间复杂度O(1)的排序
  3. python数据挖掘与机器学习实战_Python数据挖掘与机器学习技术入门实战(1)
  4. network3D 交互式网络生成
  5. 数据库笔记12:创建与管理触发器
  6. JAVA的日期与毫秒的相互转换
  7. python飞机大战项目概述需求_飞机大战需求分析报告.doc
  8. matlab m文件开方,请问,在matlab里面如果输入开方号(根号)?如9的开方怎么写?
  9. Python安装jpype,注意版本对应
  10. 元宇宙通证-十、互联网发展史全景图
  11. mysql5.5启动图解_MySQL5.5.19安装图解_MySQL
  12. 2020-11-13 Python 文件读写、os模块及递归函数
  13. 4.Transact_Sql语言基础
  14. map的put 方法的返回值 null
  15. 晋商消费金融总裁惠康获准,前不久被央行处罚49万元
  16. 我的世界服务器无限背包,我的世界无限背包存档
  17. android pixelflinger 研究,Android Pixelflinger 研究
  18. 今日头条适配方案造成Dialog显示异常的解决方法
  19. 关于jsp网页弹出窗口
  20. 19年Macbook pro type-c 供电问题,鼠标,u盘失灵,推展坞用不了。

热门文章

  1. LeetCode随缘刷题之回文数
  2. 随机变量的数字特征——方差
  3. 根据黑客的业务逻辑:最牛黑客的外号应该叫“向日葵”
  4. APS排程软件在箱包行业的应用
  5. SQL SERVER 2005镜像配置(包含见证服务器)
  6. 【深入浅出强化学习-编程实战】 7 基于策略梯度的强化学习-Cartpole(小车倒立摆系统)
  7. 金融危机 CIO增加预算力求IT安全
  8. Eureka 和nacos 的区别
  9. 60行Shell代码实现在命令行中优雅地听歌
  10. 在JSP里使用CKEditor和CKFinder