Topic: MySQL和PostgreSQL的优劣 |
Print this page |
1.MySQL和PostgreSQL的优劣 | Copy to clipboard |
Posted by: tanzhi Posted on: 2003-03-02 15:04 转-J道 Open Source开源项目大家谈 一、前言 前一段时间,我曾经翻译过一篇将你的网站从MySQL改为PostgreSQL,其实当初我更感兴趣的是一个应用程序的后台数据库从MySQL转为PostgreSQL的具体操作,并没有关心MySQL和PostgreSQL的优劣,没想到反应出乎意料的大,因此我也就觉得有写这篇文章的必要了。 在这篇文章中,我们选用MySQL 4.0.2-alpha与PostgreSQL 7.2进行比较,因为MySQL 4.0.2-alpha开始支持事务的概念,因此这样的比较对于MySQL应该较为有利。 我们这样的比较不想仅仅成为一份性能测试报告,因为至少从我个人来看,对于一个数据库,稳定性和速度并不能代表一切。对于一个成熟的数据库,稳定性肯定会日益提供。而随着硬件性能的飞速提高,速度也不再是什么太大的问题。 二、两者的共同优势 这两个产品都属于开放源码的一员,性能和功能都在高速地提高和增强。MySQL AB的人们和PostgreSQL的开发者们都在尽可能地把各自的数据库改得越来越好,所以对于任何商业数据库使用其中的任何一个都不能算是错误的选择。 三、两者不同的背景 MySQL的背后是一个成熟的商业公司,而PostgreSQL的背后是一个庞大的志愿开发组。这使得MySQL的开发过程更为慎重,而PostgreSQL的反应更为迅速。 这样的两种背景直接导致了各自固有的优点和缺点。 四、MySQL的主要优点 1、首先是速度,MySQL通常要比PostgreSQL快得多。MySQL自已也宣称速度是他们追求的主要目标之一,基于这个原因,MySQL在以前的文档中也曾经说过并不准备支持事务和触发器。但是在最新的文档中,我们看到MySQL 4.0.2-alpha已经开始支持事务,而且在MySQL的TODO中,对触发器、约束这样的注定会降低速度的功能也列入了日程。但是,我们仍然有理由相信,MySQL将有可能一直保持速度的优势。 2、MySQL比PostgreSQL更流行,流行对于一个商业软件来说,也是一个很重要的指标,流行意味着更多的用户,意味着经受了更多的考验,意味着更好的商业支持、意味着更多、更完善的文档资料。 3、与PostgreSQL相比,MySQL更适宜在Windows环境下运行。MySQL作为一个本地的Windows应用程序运行(在NT/Win2000/WinXP下,是一个服务),而PostgreSQL是运行在Cygwin模拟环境下。PostgreSQL在Windows下运行没有MySQL稳定,应该是可以想象的。 4、MySQL使用了线程,而PostgreSQL使用的是进程。在不同线程之间的环境转换和访问公用的存储区域显然要比在不同的进程之间要快得多。 5、MySQL可以适应24/7运行。在绝大多数情况下,你不需要为MySQL运行任何清除程序。PostgreSQL目前仍不完全适应24/7运行,这是因为你必须每隔一段时间运行一次VACUUM。 6、MySQL在权限系统上比PostgreSQL某些方面更为完善。PostgreSQL只支持对于每一个用户在一个数据库上或一个数据表上的INSERT、SELECT和UPDATE/DELETE的授权,而MySQL允许你定义一整套的不同的数据级、表级和列级的权限。对于列级的权限,PostgreSQL可以通过建立视图,并确定视图的权限来弥补。 7、由于MySQL 4.0.2-alpha开始支持事务的概念,因此事务对于MySQL不再仅仅成为劣势。相反,因为MySQL保留无事务的表类型。这就为用户提供了更多的选择。 8、MySQL的MERGE表提供了一个独特管理多个表的方法。 9、MySQL的myisampack可以对只读表进行压缩,此后仍然可以直接访问该表中的行。 五、PostgreSQL的主要优点: 1、对事务的支持与MySQL相比,经历了更为彻底的测试。对于一个严肃的商业应用来说,事务的支持是不可或缺的。 2、MySQL对于无事务的MyISAM表。采用表锁定,一个长时间运行的查询很可能会长时间地阻碍对表的更新。而PostgreSQL不存在这样的问题。 3、PostgreSQL支持存储过程,而目前MySQL不支持,对于一个严肃的商业应用来说,作为数据库本身,有众多的商业逻辑的存在,此时使用存储过程可以在较少地增加数据库服务器的负担的前提下,对这样的商业逻辑进行封装,并可以利用数据库服务器本身的内在机制对存储过程的执行进行优化。此外存储过程的存在也避免了在网络上大量的原始的SQL语句的传输,这样的优势是显而易见的。 4、对视图的支持,视图的存在同样可以最大限度地利用数据库服务器内在的优化机制。而且对于视图权限的合理使用,事实上可以提供行级别的权限,这是MySQL的权限系统所无法实现的。 5、对触发器的支持,触发器的存在不可避免的会影响数据库运行的效率,但是与此同时,触发器的存在也有利于对商业逻辑的封装,可以减少应用程序中对同一商业逻辑的重复控制。合理地使用触发器也有利于保证数据的完整性。 6、对约束的支持。约束的作用更多地表现在对数据完整性的保证上,合理地使用约束,也可以减少编程的工作量。 7、对子查询的支持。虽然在很多情况下在SQL语句中使用子查询效率低下,而且绝大多数情况下可以使用带条件的多表连接来替代子查询,但是子查询的存在在很多时候仍然不可避免。而且使用子查询的SQL语句与使用带条件的多表连接相比具有更高的程序可读性。 8、支持R-trees这样可扩展的索引类型,可以更方便地处理一些特殊数据。 9、PostgreSQL可以更方便地使用UDF(用户定义函数)进行扩展。 六、那么我究竟应该使用MySQL还是PostgreSQL 这个问题很难说得清,而且事实上除了MySQL和PostgreSQL外,使用Oracle、Sybase、Informix等也是明智的选择。如何你确定只在MySQL和PostgreSQL中进行选择,以下规则总是有效的。 1、如果你的操作系统是Windows,你应该使用MySQL。 2、如果你对数据库并不了十分了解,甚至不知道事务、存储过程等究竟是什么,你应该使用MySQL。 3、如果你的应用对数据的完整性和严肃性要求不高,但是追求处理的高速度。例如是一个论坛和社区,你应该使用MySQL。 4、你的应用是一个严肃的商业应用,对数据完整性要求很高。而且你希望对一些商业数据逻辑进行很好的封装,例如是一个网上银行,你应该使用PostgreSQL。 5、你的应用处理的是地理数据,由于R-TREES的存在,你应该使用PostgreSQL。 6、你是一个数据库内核的狂热爱好者,你甚至希望拥有你自己版本的数据库,毫无疑问,你必须使用PostgreSQL,没准下一个PostgreSQL版本中某一个模块的作者就是你。 七、结语 以上只是希望从我的理解客观公正地评价MySQL和PostgreSQL的优劣。其中的带有倾向性的意见只代表个人观点,由于本人水平的限制,有不当之处还请批评指正。 评论: MySQL当数据库大到一定规模的时候,速度会变得慢下来。 还有MySQL 的 sort 非常消耗系统资源。 |
2.Re:MySQL和PostgreSQL的优劣 [Re: tanzhi] | Copy to clipboard |
Posted by: sho Posted on: 2003-03-02 16:23 我認為應該加上價格上的比較.... postgresql是100% free...... 但mysql在很多情形下不是free...... 價格可看http://www.mysql.com/products/pricing.html 以下轉自http://www.mysql.com/products/licensing.html In Brief This is our licensing policy in brief: Our software is 100% GPL, and if yours is ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ also 100% GPL (or OSI compliant), then you never have to pay us for the ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ licences. In all other instances, you are better served by our commercial ~~~~~ licence. Read the details below! Licensing MySQL software is licensed under the GPL license. The formal terms of the GPL license can be found in the GNU General Public License section of the MySQL Reference Manual. MySQL is also available under commercial non-GPL license. For pricing and ordering information, see our online store 1. Free use for those who are 100% GPL If your application is licensed under GPL or compatible OSI license approved by MySQL AB, you are free and welcome to ship any GPL software of MySQL AB with your application. By "application" we mean any type of software application, system, tool or utility. For doing this, you do not need a separate signed agreement with MySQL AB, because the GPL text is sufficient. But we do recommend you to be in touch with us as there usually are good opportunities for partnership and co-marketing. 2. Free use for those who never copy, modify or distribute As long as you never distribute (internally or externally) the MySQL Software in any way, you are free to use it for powering your application, irrespective of whether your application is under GPL or other OSI approved license or not. More specifically: Modifying - You are allowed to modify MySQL Software source code any way you like. If you distribute the modified version, all changes, all interface code and all code that connects directly or indirectly to the interface code fall under GPL. Copying - You are allowed to copy MySQL binaries and source code, but when you do so, the copies will fall under the GPL license. 3. Commercial use for everyone else If your application is not licensed under GPL or compatible OSI license approved by MySQL AB and you intend to distribute MySQL software (be that internally or externally), you must first obtain a commercial license to the MySQL software in question. More specifically: a) If you include the MySQL server in your non Open Source application, you need a commercial licence for the MySQL server b) If you include one of the MySQL drivers in your non Open Source application (so that your application can run with MySQL), you need a commercial licence for the driver(s) in question. The MySQL drivers currently include an ODBC driver, a JDBC driver and the C language library. c) If you use MySQL Software within your organisation and you don't want to risk it falling under the GPL license, you are welcome to purchase a commercial license. d) Many users opt for the commercial licence simply because under it MySQL AB takes responsibility for its products. Under the GPL licence, there are no warranties or representations from the developer (i.e. from MySQL AB). 4. Exceptions and free commercial licences If you represent a non-profit organisation or an academic institution, we recommend you to put your own application under GPL. Thereby you are free to use MySQL software free of charge under the GPL licence. (We also believe that if you have strong reasons not to go GPL, you also have the monetary means to purchase commercial licences.) If you are a private individual you are free to use MySQL software for your personal applications, as long as you do not distribute them. Please note that even if you ship a free demo version of your own application, the above rules apply. 5. Finally, what is the recommendation? To all commercial organisations we do recommend the commercial licence. Not only does this free you from the far-reaching requirements of the GPL licence, it also gives you a licence letter from MySQL AB where we assume responsibility for our product. The GPL licence is an "as is" licence with no warranties whatsoever. To all GPL/Open Source enthusiasts we do recommend our products under the GPL licence. We believe that MySQL AB is the world's largest company that offers all its software under the GPL licence. So help yourself to the MySQL server and the drivers and feel the freedom of free software! To anyone in doubt, we recommend the commercial licence. It is never wrong. Thanks to our cost-effective way of producing software, we are able to sell our commercial licences at prices well under the industry average, and this is without compromising our own profitability. And, as evidenced by benchmarks and our installed base of millions, our software beats the old legacy databases in both performance and stability. Older Versions Note that older versions of the MySQL database server are still using a stricter license. See the documentation for the specific version for more information. MySQL Licenses For circumstances under which a commercial non-GPL MySQL server license is required, you need a license per database server (single installed MySQL binary). There are no restrictions on the number of connections, number of CPUs, memory or disks to that one database server. For circumstances under which a commercial non-GPL MySQL client license is required, you need a license per each installed application. When in doubt If you have any questions on MySQL licensing, feel free to contact us. OSI = Open Source Initiative, www.opensource.org/licenses GPL = Gnu General Public License, http://www.gnu.org/copyleft/gpl.html |
3.Re:MySQL和PostgreSQL的优劣 [Re: tanzhi] | Copy to clipboard |
Posted by: chaos Posted on: 2003-03-02 17:46 how about : SAPDB http://www.sapdb.org/ and Firebird http://firebird.sourceforge.net |
4.Re:MySQL和PostgreSQL的优劣 [Re: tanzhi] | Copy to clipboard |
Posted by: jenson Posted on: 2003-03-02 18:54 我认为SAP DB相当稳定,据我所知SAP内部的开发和测试系统很多都采用SAP DB. |
Powered by Jute Powerful Forum® Version Jute 1.5.6 Ent Copyright © 2002-2021 Cjsdn Team. All Righits Reserved. 闽ICP备05005120号-1 客服电话 18559299278 客服信箱 714923@qq.com 客服QQ 714923 |