Mongoid和Postgres脚手架/关系

时间:2012-05-28 20:00:11

标签: ruby-on-rails postgresql mongodb activerecord mongoid

我需要某个模型来包含对文档的引用。大部分模型都可以存储在postgres中。该模型适用于"级别"在游戏中。我希望将级别数据本身存储在文档中,这比在sql中创建复杂树更有意义。

我可以使用安装了mongoid的postgres;然而,在安装mongoid gem之后,我似乎只能够构建mongoid(非活动记录)文档。

问题在于我引用了其他表格,并且我并不知道如何在mongoid模型中将其链接起来。

问题:

  1. 如何使用活动记录强制脚手架而不是mongoid,反之亦然。 修改:部分回答:Using Active Record generators after Mongoid installation?(第二个回答有效,但我不知道如何轻松地来回走动)

  2. 是否有一种简单的方法可以从活动记录模型中引用文档(我知道文档说不要混合它们,但它是我想要做的事情的理想选择)。

  3. 如果无法混合它们,那么我应该如何从postgres / active记录表中引用文档。换句话说,如何同时获取两个数据?

  4. 谢谢!

1 个答案:

答案 0 :(得分:6)

关于你的第一个问题,理想的解决方案将与参考文章中的第一个答案一致。但是,不是生成迁移,而是生成模型。因此,当您想要一个Active Record模型时,只需运行:

rails g active_record:model

关于第二个和第三个问题,要将Active Record模型与Mongoid文档相关联,只需将ObjectId存储为模型中的字符串即可。然后,当您获取检索记录时,从字符串中生成一个新的ObjectId并使用它来查询相关文档。

您可以使用以下字符串创建对象ID:

BSON::ObjectId.from_string("object_id_string")

在ActiveRecord和Mongoid之间进行混合和匹配时,没有一种简单的方法可以轻松地遵循内部关系,但我担心必须通过Ruby代码完成。

您在rails中定义的模型要么扩展一个ORM的基类,要么扩展另一个,并且它们彼此不了解。可能有一些项目作为这些ORM之上的一层,但我不熟悉目前存在的任何项目。