mongodb vs. postgres:建模条件

时间:2012-07-25 10:24:57

标签: mongodb postgresql schema-design database nosql

我们现在正在为项目选择一个数据库。候选人是mongodb和postgres。我们的用户需要定义条件逻辑,例如用户定义条件(作为字符串)“x发生”,“y离开”等,然后可以将它们连接到条件“如果x发生AND(y离开OR z出现)......”。

在单个json文档中执行此操作似乎比在关系数据库中更具可读性。

你有没有办法在postgres中合理地建模?我知道postgres 9.2将支持json,但查询功能似乎很笨拙。

在mongo中,动词(“x恰好”)将在条件之间重复。动词更新将影响多行。你觉得这里有问题吗?

编辑:mongo文档可能如下所示:

{
  "where": 
     [1,"x happens"],
     "and": 
     { "where": 
            [2,"y leaves"], 
               "or": 
            [3,"z comes"]
     }
}

1 个答案:

答案 0 :(得分:0)

好的,在这个领域,PostgreSQL和MongoDB将会有很大的不同,但在如何思考这个方面却非常相似。最重要的是摆脱严格的关系理念。您的选择是对象关系或面向文档。我会选择前者,因为我对它更加满意。

关键是你必须能够将你的条件减少到可以在飞行中定义的bool。如果你在PostgreSQL中这样做,你将有一些编程要做。需要权衡的是,您可以获得在MongoDB中难以处理的临时报告。

你可以在Postgres做的关键是模型衍生数据。所以PostgreSQL中使这个可管理的关键是使用表方法在运行时检查约束。要在PostgreSQL中创建表方法,请使用如下形式:

CREATE OR REPLACE FUNCTION method_name(table_name) RETURNS return_type ....

您可以通过更多示例找到这些内容:http://ledgersmbdev.blogspot.com/2012/08/postgresql-or-modelling-part-2-intro-to.html(是的,这是我的博客)。

事实是你可以在PostgreSQL上构建一些极其复杂的准关系模型,所以我不会在这方面排除它。问题在于您是否需要关系方面,以进行即席查询和报告对象集。如果你这样做,那么单独的Mongo就不会削减它,你可以从Mongo导出到Postgres或者在PostgreSQL中做事。

这并不是说PostgreSQL就是答案。如果您永远不需要添加新的查询类型,也许Mongo会更好。然而,这是你真正想要使用Pg为你提供的所有高级功能的情况之一,如果你要走这条路线,那么这对你的情况很有用。