当前位置: 首页 > 面试题库 >

Postgres 9.1与Mysql 5.6 InnoDB?

郎同化
2023-03-14
问题内容

一个简单的问题-2012年对于要求与ACID兼容的中型/大型数据库,哪个会更好?

我已经阅读了所有有关MySQL和pgSQL的文章(大部分),但其中大多数文章分别与版本4,5.1和7,8有关,并且过时(2008、2009)。现在已经快到2012年了,所以我想我们可以尝试重新审视这个问题。

基本上,我想知道PostgreSQL中是否有任何东西超过了MySQL的易用性,可用性和更大的开发人员/知识基础。

MySQL的查询优化器仍然很愚蠢吗?在非常复杂的查询上它仍然超级慢吗?

打我!:)

PS。而且不要将我发送到Google或Wiki。我正在寻找一些特定的要点而不是概述+我更信任StackOverflow,而不是一些随机页面,其中“聪明的家伙”光芒四射。

附录

项目规模 :假设一个订购系统每个帐户每天大约有10-100个订单/天,几千个帐户,最终每个帐户可以有数百到数千个用户。

擅长 :适应不断增长的需求和不断变化的需求时,要具有面向未来的灵活性。性能对于降低硬件部门的成本也很重要。熟练劳动力的可用性也是一个因素。

OLTP或OLAP :OLTP


问题答案:

MySQL的查询优化器仍然很愚蠢吗?在非常复杂的查询上它仍然超级慢吗?

所有
查询优化器有时都是愚蠢的。在大多数情况下,PostgreSQL并不那么愚蠢。PostgreSQL的一些最新SQL功能(窗口函数,带有查询的递归等)非常强大,但是如果您使用的是愚蠢的ORM,则可能无法使用。

项目规模:假设一个订购系统每天每个帐户大约10-100个订单,成千上万个帐户,最终每个用户可以拥有数百到数千个用户。

听起来不那么大-完全在一个大盒子里。

擅长:适应不断增长的需求和不断变化的需求,它具有面向未来的灵活性。

PostgreSQL拥有强大的开发团队,并拥有广泛的贡献者社区。发行政策是严格的,仅在关键发行版本中有错误修正。始终跟踪9.1.x的最新版本以获取错误修复。

过去,MySQL对版本号的态度较为宽松。甲骨文负责可能会改变这种情况。我对各种分叉的政策不熟悉。

性能对于降低硬件部门的成本也很重要。

如果硬件竟然是这个规模的项目中的主要组件,我会感到惊讶。

熟练劳动力的可用性也是一个因素。

那是您的关键决定者。如果您有一群经验丰富的Perl + PostgreSQL黑客闲着闲逛,请使用它。如果您的员工知道Lisp和MySQL,请使用它。

OLTP或OLAP:OLTP

PostgreSQL在OLTP上一直很强大。

我个人的观点是PostgreSQL邮件列表中充满礼貌,乐于助人,知识渊博的人。您可以直接与拥有Terabyte数据库的用户和建立html" target="_blank">代码主要部分的黑客联系。支持的质量确实非常出色。



 类似资料:
  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认

  • 问题内容: 我今天刚刚与一些同事讨论了python的db-api fetchone vs fetchmany vs fetchall。 我确定每个应用程序的用例都取决于我正在使用的db-api的实现,但是总的来说,fetchone,fetchmany,fetchall的用例是什么? 换句话说,以下等效项是什么?还是其中之一比其他人更受青睐?如果是这样,在哪些情况下? 问题答案: 我认为这确实取决于

  • 问题内容: 即时创建元素并能够移动元素的最佳方法是什么?例如,假设我要创建一个矩形,圆形和多边形,然后选择这些对象并四处移动。 我了解HTML5提供了三个使之成为可能的元素:svg,canvas和div。对于我想做什么,这些元素中的哪一个将提供最佳性能? 为了比较这些方法,我正在考虑创建三个视觉上相同的网页,每个网页中都有页眉,页脚,小部件和文本内容。第一页中的小部件将完全使用元素创建,第二页中的

  • 问题内容: 之间有什么区别,和? 问题答案: 将等待,直到所有资产完成下载为止,例如图像和脚本。 DOM准备就绪,直到您可以通过API访问DOM为止。 作为一个方面说明,在当今这个时代,你应该使用或较旧的IE。