1.Posgresql是进程模式,多进程,单线程,类似的还有Oracle。而MYSQL采用的是线程模式,单进程,多线程,对此,大家在运行数据库的时候可以查看任务管理器,SQL Server也是如此。

众所周知,多进程,进程模式,利用CPU时间片轮转,可以利用更充分CPU,因此光拿多核单台机器上来说,他明显在支持高并发性能方面更胜一筹。而线程模式呢,开一个线程显然要比开一个进程所耗费的资源要少,另外在不同线程之间的环境转换和访问公用的存储区域,显然比在不同进程之间要快,所以它的处理速度要快,对资源的消耗较少,但是当高并发时,性能不佳。

2.存储引擎。Posgresql只有一个存储引擎,且综合性能良好。而MYSQL支持不同表使用不同的存储引擎。如MYISAM,InnoDB(Oracle所有),memory。在mysql中配置有许多不同的存储引擎,用户可以灵活的选择适用于服务器、数据库和表格的存储引擎,以便获得最大的性能和最大的灵活性。这也是mysql不同于其他大型数据库以及mysql为何如此受欢迎的主要因素。借鉴说明一下MYSQL中重要的3个存储引擎的特点:

每种存储引擎都有各自的优势,不能笼统的说谁的性能更好,只有合适不合适。

(1)MyISAM存储引擎:主要用于管理非事物表,它提供了高速的存储与检索,以及全文搜索能力。该存储引擎插入数据快,但是空间和内存的使用效率较低。如果表主要适用于插入新纪录和读出记录,那么选择MyISAM存储引擎可以实现处理的高效率,不支持事物的提交和回滚,查询时会把整个表锁定,但是速度快

(2)InnoDB存储引擎:它主要用于事务处理应用程序,支持外键,同时还支持奔溃修复能力和并发控制。如果对事物的完整性要求比较高,要求实现并发通知,那么选择InnoDB存储引擎比较有优势。如果需要频繁的进行更新、删除操作,也可以选择该存储引擎,因为该存储引擎可以实现事物的提交和回滚。(所以事物就是对实时性要求比较高)

(3)Memory存储引擎:Memory存储引擎提供“内存中”表,该存储引擎的所有数据都存储在内存中,数据的处理速度很快但是安全性不高。

3.对于MYSQL来说,它目前使用更为普遍,所以它的商业支持和应有要好于Posgresql,这一点如果要商业应用也是不可以忽视的。

历史对比  

 PostgreSQL社区是同类数据库历史最悠久,规模最大,发展最快的社区,PostgreSQL起源于1985年加州伯克利大学的Ingress项目,在学术界流行多年后,PostgreSQL项目开源了,社区开始蓬勃发展,截至目前,有超过1000名贡献者和3万名成员。   大社区的关键优势在于用户和开发者之间的互动比较频繁,用户甚至可以直接参与到新功能的设计中,这种多元化的社区模式也是其它开源社区争相模仿的模式。   MySQL社区最初起源于商业世界,MySQL于1994年诞生在瑞典,作为网站背后的高速数据库,在MySQL AB公司控制几年后,MySQL也选择了开源,有商业公司的支持使得MySQL很快便成为世界上广泛使用的数据库之一,这也是Sun公司2008年花10亿美元重金收购MySQL AB的原因,因为MySQL的流行,也成为欧盟调查Oracle收购Sun一案的主要因素。

  PostgreSQL特性和功能  

 通过数十年的发展,PostgreSQL被誉为市场上最先进的开源数据库,作为一个功能全面的开源关系数据库管理系统,PostgreSQL在支持高事务,关键任务应用方面提供了许多特性。   PostgreSQL最核心的竞争力是对它保管的数据的安全保护能力,通过使用企业身份验证机制,如LDAP或Kerberos控制数据库的连接访问,一单通过验证,所有到数据库的通信都可以走SSL连接,提供了高度安全的保护。   添加或修改数据时,PostgreSQL强制执行用户定义的大量约束,确保数据质量符合业务规则限制,从简单的范围检查到复杂的外键检查,一旦数据存储到磁盘上,就可以进行备份,更重要的是,从灾难恢复是至关重要的,PostgreSQL有一个简单的在线备份工具,配合时间点恢复(PITR)机制,为管理员执行快速恢复提供了很好的灵活性。   PostgreSQL的核心架构允许其他社区小组通过附加模块的形式为PostgreSQL创建更高级的功能,一个很好的例子就是PostgreSQL的地理空间支持,此功能来自一个名为PostGIS的模块,它是PostgreSQL的一个简单扩展,使其成为最强大的可保存空间数据的开源或商业数据库。   PostgreSQL另一个扩展能力是它具有多种不同类型的存储过程语言,允许开发人员使用他们熟悉的语言编写服务器端代码,例如,需要执行复杂文本处理的触发器可以用Perl编写,以便利用其强大的正则表达式功能。  

 MySQL特性和功能

  MySQL被誉为是最流行的开源数据库,从一开始,MySQL就被设计为适合网站快速顺序索引方法(ISAM)的数据存储引擎,这种工作负载的一大特点就是有许多小型查询,于是催生了查询缓存,MySQL集群等提高MySQL性能的技术,MySQL集群允许数据库跨多台物理服务器部署,实现负载均衡。   PostgreSQL不是唯一允许通过外部扩展增加数据库功能的开源数据库,MySQL最大的优势之一就是它的可插入式存储引擎,MySQL默认采用的是MyISAM存储引擎,为读操作频繁的环境提供更好的性能,而InnoDB存储引擎更适合写密集型事务环境。   此外,还有许多第三方存储引擎,如Brighthouse和DB2,这种灵活性允许管理员根据每个表的需求调整MySQL实例,例如,对一个读操作频繁的表,如国家代码表,使用MyISAM存储引擎,对于事务型表,如销售订单表,则使用InnoDB存储引擎。   PostgreSQL和MySQL在各种应用场合都得到了广泛的使用,例如,PostgreSQL一向以强力支撑事务密集型企业应用而著名,但许多网站也用它来支撑Web应用程序,相反,MySQL一直都是Web应用程序的首选数据库,但它在事务型企业应用系统中也得到了大量使用。  

 社区为王  

 PostgreSQL和MySQL最大的不同可能不在技术,而是在社区上,开源项目从本质上来讲,要由社区开发人员参与和贡献,项目才能保持活力,开源社区有两种不同的类型。   首先,有独立自主社区型纯开源数据库项目,PostgreSQL是这种最古老,最大的独立开源数据库社区,这种社区的好处是真正独立于厂商,不受厂商控制。   第二种开源社区是由厂商控制的,这种开源项目往往同时有社区免费版和商业付费版,MySQL就是一个例子,MySQL项目最初是由MySQL AB资助和控制的,所有MySQL核心开发人员和架构师都由MySQL AB出资雇佣,被Sun收购后,MySQL社区就被Sun控制,现在又被Oracle控制。  

 共享许可  

 许可,或源代码允许如何修改和共享,这可能是真正影响开源数据库选择的决定性因素,PostgreSQL许可是仿照BSD许可模式的,它允许修改代码,并根据修改者自愿是否以开源形式再发布,这种开放式许可对想使用PostgreSQL作为他们解决方案一部分的软件厂商来说是最理想的,因为PostgreSQL许可不强制衍生解决方案也开源,软件厂商可以选择开放他们的源码,也可以不开放。   MySQL是通过GNU GPL共享,并由Oracle控制,GNU GPL更加开放,它鼓励免费共享代码,它防止了采用GNU GPL共享的代码后,也被迫采用源作者GNU GPL许可共享的缺陷。   

小结  

 虽然PostgreSQL和MySQL同属开源数据库,但相同点也可能仅限于此,重叠的地方很少,它们都有自己鲜明的特性,相对于昂贵的专有数据库产品,它们都是高品质的开源数据库,尤其是在当今经济不景气的环境下,选择优秀的开源数据库不失为为企业节省成本的一种好方法。

最新文章

  1. pip 安装插件慢的解决方法
  2. javap反编译解释外部类直接使用内部类private字段的原理
  3. node中global
  4. GitHub 操作流程示例
  5. IT客学院《构建高转化率的着陆页-PS+HTML+网络营销》共25节【价值199元】无水印版
  6. 浅谈Apache Spark的6个发光点(CSDN)
  7. Oracle数据库编程:在JDBC中应用Oracle
  8. oracle建用户
  9. QTP鼠标点击和浏览器事件的动态切换
  10. ADO.NET中使用事务进行数据库读写的办法
  11. Spark Streaming 实现读取Kafka 生产数据
  12. 如何安装VM Tool软件包
  13. 玩转INotifyPropertyChanged和ObservableCollection
  14. classpath和filepath
  15. TensorFlow读写数据
  16. SSM框架开发遇到的问题
  17. spring boot -thymeleaf-异常处理
  18. [nodejs] nodejs开发个人博客(四)数据模型
  19. vue-router(配置子路由--单页面多路由区域操作)
  20. C#一年中有多少周方法和js一年中第几周

热门文章

  1. C# Xamarin移动开发项目实战篇
  2. puttygen 命令行 id_rsa.pub 转 ppk
  3. bootstrap3-iframe-modal子页面在父页面显示模态框
  4. GBK转UTF8
  5. Google Maps V3 之 路线服务
  6. mysql 线程等待时间,解决sleep进程过多的办法
  7. 批量生产Xcode group 并映射 实体目录
  8. Android 提高 gradle 的编译速度
  9. SQL Server does not purge row versioning records even the transaction are committed if there are other open transaction running in the databases with read-committed snapshot enabled .
  10. curl模拟访问已经存在的cookie