百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> pg数据库和mysql的区别有哪些?
分享文章到:

pg数据库和mysql的区别有哪些?

发布时间:09/01 来源:未知 浏览: 关键词:

不同:1、MySQL倾向于使用者的角度;pg数据库倾向于理论角度。2、MySQL一样会将数据合法性验证交给客户;pg数据库在合法性难方面做得比力严厉。3、在SQL的标准实现上,pg数据库要比MySQL完美,并且功效实现比力严谨。

MySQL

MySQL相对来说比力年轻,首度显现在1994年。它声称本人是最流行的开源数据库。MySQL就是LAMP(用于Web开发的软件包,包罗 Linux、Apache及Perl/PHP/Python)中的M。构建在LAMP栈之上的大多数利用都会使用MySQL,包罗那些知名的利用,如 WordPress、Drupal、Zend及phpBB等。

一开端,MySQL的设计目标是成为一个快速的Web效劳器后端,使用快速的索引序列拜访办法(ISAM),不支撑ACID。经过早期快速的开展之 后,MySQL开端支撑更多的储备引擎,并通过InnoDB引擎实现了ACID。MySQL还支撑其他储备引擎,供给了暂时表的功效(使用MEMORY存 储引擎),通过MyISAM引擎实现了高速读的数据库,此外还有其他的中心储备引擎与第三方引擎。

MySQL的文档非常丰硕,有许多质量不错的免费参照 手册、图书与在线文档,还有来自于Oracle和第三方厂商的培训与支撑。

MySQL近几年经历了所有权的变动和一些颇具戏剧性的事件。它最初是由MySQL AB开发的,然后在2008年以10亿美金的价钱卖给了Sun公司,Sun公司又在2010年被Oracle收购。Oracle支撑MySQL的多个版 本:Standard、Enterprise、Classic、Cluster、Embedded与Community。其中有一些是免费下载的,别的一 些则是收费的。其中心代码基于GPL许可,关于那些不想使用GPL许可的开发者与厂商来说还有商业许可可供使用。

此刻,基于最初的MySQL代码还有更多的数据库可供选中,由于几个中心的MySQL开发者已经公布了MySQL分支。最初的MySQL创立者之一 Michael “Monty” Widenius貌似懊悔将MySQL卖给了Sun公司,于是又开发了他本人的MySQL分支MariaDB,它是免费的,基于GPL许可。知名的 MySQL开发者Brian Aker所创立的分支Drizzle对其停止了大量的改写,特殊针对多CPU、云、网络利用与高并发停止了优化。

PostgreSQL

PostgreSQL标榜本人是世界上最先进的开源数据库。PostgreSQL的一些粉丝说它能与Oracle相比美,并且没有那么昂贵的价钱和傲慢的客服。它具有很长的历史,最初是1985年在加利福尼亚大学伯克利分校开发的,作为Ingres数据库的后继。

PostgreSQL是完全由社区驱动的开源项目,由全世界超越1000名奉献者所保护。它供给了单个完全功效的版本,而不像MySQL那样供给了 多个不一样的社区版、商业版与公司版。PostgreSQL基于自在的BSD/MIT许可,组织可以使用、复制、修改和从新分发代码,只需要供给一个版权声 明即可。

可靠性是PostgreSQL的最高优先级。它以安如磐石的品质和良好的工程化而著名,支撑高事务、任务关键型利用。PostgreSQL的文档非 常精良,供给了大量免费的在线手册,还针对旧版本供给了归档的参照 手册。PostgreSQL的社区支撑是非常棒的,还有来自于独立厂商的商业支撑。

数据一致性与完全性也是PostgreSQL的高优先级特性。PostgreSQL是完全支撑ACID特性的,它关于数据库拜访供给了强大的平安性 包管,充分利用了公司平安工具,如Kerberos与OpenSSL等。你可以定义本人的检查,按照本人的业务规则确保数据质量。在众多的治理特性 中,point-in-time recovery(PITR)是非常棒的特性,这是个灵敏的高可用特性,供给了诸如针对失败复原创立热备份乃至快照与复原的能力。但这并不是 PostgreSQL的全部,项目还供给了几个办法来治理PostgreSQL以实现高可用、负载平衡与复制等,这样你就可以使用适合本人特定需求的功效 了。

平台

MySQL与PostgreSQL都显现在一些高流量的Web站点上:

MySQL:Slashdot、Twitter、Facebook与Wikipedia

PostgreSQL:Yahoo使用了一个修改的PostgreSQL数据库来处置每天数以亿计的事件,还有Reddit和Disqus

MySQL与PostgreSQL都能运转在多个操纵系统上,如Linux、Unix、Mac OS X与Windows。他们都是开源、免费的,因此测试他们时的独一代价就是你的时间与硬件。他们都很灵敏且具有可伸缩性,可用在小型系统和大型分布式系统 上。MySQL在一个领域上要比PostgreSQL更进一步,那就是它的触角延长到了嵌入式领域,这是通过libmysqld实现的。 PostgreSQL不支撑嵌入式利用,仍然据守在传统的客户端/效劳器架构上。

MySQL平常被认为是针对网站与利用的快速数据库后端,能够停止快速的读取和大量的查询操纵,不外在复杂特性与数据完全性检查方面不太尽善尽美。

PostgreSQL是针对事务型公司利用的严厉、功效完美的数据库,支撑强ACID特性和许多数据完全性检查。他们二者都在某些任务上具有很快的速 度,MySQL不一样储备引擎的行动有较大差异。MyISAM引擎是最快的,由于它只施行很少的数据完全性检查,适合于后端读操纵较多的站点,不外关于包括 敏锐数据的读/写数据库来说就是个劫难了,由于MyISAM表终究大概会破坏。MySQL供给了修复MySQL表的工具,不外关于敏锐数据来说,支撑 ACID特性的InnoDB则是个更好的选中。

与之相反,PostgreSQL则是个只要简单储备引擎的完全集成的数据库。你可以通过调整postgresql.conf文件的参数来改善机能,也可以调整查询与事务。PostgreSQL文档关于机能调优供给了非常详实的介绍。

MySQL与PostgreSQL都是高可配置的,并且可以针对不一样的任务停止响应的优化。他们都支撑通过扩展来增加额外的功效。

一个常见的曲解就是MySQL要比PostgreSQL更容易学习。关系数据库系统都是非常复杂的,这两个数据库的学习曲线其实是差不多的。

标准兼容性

PostgreSQL旨在实现SQL兼容性(当前标准是ANSI-SQL:2008)。MySQL则兼容大部分SQL,不外还有本人的扩展,可以支 持NoSQL特性,这在参照 手册中都有介绍。每种方式都有优缺陷。兼容标准会让数据库治理员、数据库开发者与利用开发者更舒适一些,由于这意味着他们只需 学习一套标准、一套特性和命令即可。这会节约时间,晋升效力,也不会被锁定在特定的厂商上。

支撑使用非标准的自定义功效的人们认为这样可以快速采纳新的特性,而不必等候标准进程完成。ANSI/ISO标准在不竭演化,因此标准兼容性也是个 转变的目标:知名的关系型数据库Microsoft SQL Server、Oracle与IBM DB2也只是部分兼容于标准。

MySQL与PostgreSQL(pg数据库)的不同

MySQL是利用开发者创立出来的DBMS;而PostgreSQL是由数据库开发者创立出来的DBMS 。

换句话说,MySQL倾向于使用者的角度,答复的问题是 “你想解决的是啥问题”;而PostgreSQL倾向于理论角度,答复的问题是 “数据库应当怎样来解决问题” 。

MySQL一样会将数据合法性验证交给客户;PostgreSQL在合法性难方面做得比力严厉。比方MySQL里插入 “2012-02-30” 这个时间时,会成功,但结果会是 “0000-00-00”;PostgreSQL不同意插入此值。

平常,PostgreSQL 被认为特性丰硕,而MySQL被认为速度更快。但这个观念根本是在 MySQL 4.x / PostgreSQL 7.x 的事情,此刻状况已经变了,PostgreSQL 在9.x版本速度上有了很大的改善,而MySQL特性也在增添。

在架构上,MySQL分为两层:上层的SQL层和几个储备引擎(比方InnoDB,MyISAM)。PostgreSQL 只要一个储备引擎供给这两个功效。

这两个数据库系统都可以针对利用的情境被优化、定制,准确的说哪个机能更好很难。MySQL项目一开端焦点就在速度上,而PostgreSQL一开端焦点在特性和标准标准上。

PostgreSQL相关于MySQL的优势

1、在SQL的标准实现上要比MySQL完美,并且功效实现比力严谨;

2、储备历程的功效支撑要比MySQL好,具备当地缓存施行方案的能力;

3、对表连接支撑较完全,优化器的功效较完全,支撑的索引类型许多,复杂查询能力较强;

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

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

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

MySQL相关于PG的优势:

1、innodb的基于回滚段实现的MVCC机制,相对PG新老数据一起存置的基于XID的MVCC机制,是占优的。新老数据一起存置,需要按时触 发VACUUM,会带来余外的IO和数据库对象加锁开销,引发数据库团体的并发能力下落。并且VACUUM清算不及时,还大概会激发数据膨胀;

2、MySQL采纳索引组织表,这种储备方式非常适合基于主键匹配的查询、删改操纵,但是对表构造设计存在束缚;

3、MySQL的优化器较简便,系统表、运算符、数据类型的实现都很精简,非常适合简便的查询操纵;

4、MySQL分区表的实现要优于PG的基于继承表的分区实现,主要表现在分区个数到达上千上万后的处置机能差别较大。

5、MySQL的储备引擎插件化机制,使得它的利用场景愈加广泛,比方除了innodb适合事务处置场景外,myisam适合静态数据的查询场景。

相关引荐:《mysql教程》

以上就是pg数据库和mysql的不同是啥?的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有152人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板