如果不是领导强制要求,可能根本不会留意到这款号称世界上功能最强大的开源数据库——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

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

  2. PostgreSQL入门(一)——世界上最先进的开源数据库

    前言 首先声明PostgreSQL声称自己是世界上最先进的开源数据库,但是我刚刚接触这个sql,公司原本使用的是orcale,现在的系统都在做兼容PostgreSQL数据库,可能会逐步的替代oracl ...

  3. php postgresql linux,系统运维|在 Ubuntu 上安装世界上最先进的开源数据库 PostgreSQL 9.4 和 phpPgAdmin...

    简介 PostgreSQL 是一款强大的,开源的,对象关系型数据库系统.它支持所有的主流操作系统,包括 Linux.Unix(AIX.BSD.HP-UX,SGI IRIX.Mac OS.Solaris ...

  4. 世界上最强大的开源数据库,你了解多少呢?

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

  5. 世界上第一个便便数据库需要您的帮助!【智能快讯】

    By 超神经 AI 无处不在的时代,每天都有新的技术与研究成果出现.无论学术界还是商界,技术还是产品,AI 的新发现都源源不断,在带给我们全新视角的同时,也引起我们更深的思考. 想知道最近的 AI 动 ...

  6. 哥大创建了世界上第一个医用毒液数据库

    你听说过不会毒杀人反而可以治愈人的毒素吗?由于对动物毒液治疗价值的兴趣日益增长,一对哥伦比亚大学的数据科学家创建了关于已知动物毒素及其对人类的生理效应的第一个目录. VenomKB,简称毒液知识库,总 ...

  7. 开源数据库成为发展自主可控产品的主要途径 ▏开源数据库系列谈之三

    利用开源的资源和机制,国内出现了众多的基于开源系统的数据库产品,涉及种类繁多,应用扩大.目前,开源数据库已经成为国产数据库实现突围,发展自主可控产品的主要途径. -------- 作者:刘学习 在信息 ...

  8. MySQL与PostgreSQL:该选择哪个开源数据库?哪一个更好?

    Naresh Kumar是一位软件工程师与热情的博主,对编程与新事物充满了激情和兴趣.近日,Naresh撰写了一篇博文,对开源世界最常见的两种数据库MySQL与PostgreSQL的特点进行了详尽的分 ...

  9. zz业界大家谈之苹果必须死和世界上最奇葩的公司谷歌

    先从个人移动通讯行业说起.     自从这个世界上发明了数字移动通信网络以后,同学们能用手机打电话主要靠俩帮人在做  生意: 一伙人是弄基站的,基站弄好了才有信号啊! 一伙人是卖手机的,这样你买个手机 ...

最新文章

  1. 服务认证暴力破解工具Crowbar
  2. 基于pygame的射击小游戏制作(三)让外星人动起来
  3. Linux系统MySQL开启远程连接
  4. Java面试题集(二)list与Map相关知识(1.2)
  5. view [bootstrap-4] not found如何解决_Dubbo如何处理业务异常,这个一定要知道哦
  6. butter滤波器是iir吗_IIR低通滤波器求改
  7. (18)Zynq FPGA 看门狗定时器介绍
  8. 树莓派(0)C语言教材学习
  9. Mobile Terminal 316s-7 使用技巧
  10. matlab解超越函数,矩阵的超越函数Matlab提供的矩阵函数.PPT
  11. 信度spss怎么做_毕业季:毕业论文利用spss做信度分析步骤详解
  12. 加载mysql驱动失败_java mysql 驱动加载失败
  13. 嵌入式与物联网的关系还是挺复杂的,去同存异分析一波
  14. 如何通过Facebook主页获得用户的邮箱
  15. HFSS和CST电磁仿真的硬件选型指南(纯个人经验)
  16. spyder 护眼背景--纯黑色
  17. CSDN 2018博客之星活动报名开始了!
  18. 【无标题】2022年施工员-设备方向-通用基础(施工员)考试模拟100题及模拟考试
  19. 信息学奥赛一本通:1309:【例1.6】回文数(Noip1999)
  20. [LightOJ1070]Algebraic Problem

热门文章

  1. usb扫描枪驱动下载 wince_wince下USB设备驱动程序
  2. 跨境电商:外贸企业做海外社媒营销的优势
  3. java test1
  4. comsol技巧学习 day1
  5. Linux管道初步了解
  6. android 手机震动1次,Android的手机震动
  7. 用django实现一个资产管理的系统
  8. 【PdgCntEditor】解决PDF的目录页码和PDF实际页码不一致的问题,书签页码偏移页面偏移功能,PDF页面标签的添加
  9. 查看电脑已连接过的账号密码
  10. vi编辑器 末尾添加_vi编辑器操作指令分享