我有主模型页面,它是容器。 该页面可以包含一些待办事项列表,备注,文件和讨论。我们的想法是让它们按特殊顺序排列。
Page.last.container # [Todolist_obj, Note_obj, File_obj, Note_obj, Discussion_obj, File_obj, File_obj]
所以我开始使用Mongodb
或者我也考虑过将Postgres与hstore一起使用,但不知道它是否会有所帮助
或者可能只是任何数据库并在获取页面时反序列化所有对象,并在保存时序列化对象
或者我可以使用MTI创建超类Item并从中继承所有包含对象,并使Page有很多关系。
所以我不知道哪种方式最好?
或者有更好的方法?
答案 0 :(得分:1)
我已经使用acts_as_list非常成功地实现了可排序对象。另外,我会将页面元素抽象为一个单独的模型,这里称为PageElement
。
我认为没有必要切换到NoSQL数据库(虽然我没有反对这种方法)。这是我正在思考的草图:
class Page < ActiveRecord::Base
has_many :page_elements, :order => 'position'
has_many :todo_lists, :through => :page_elements, :source => :element, :source_type => 'TodoList'
has_many :notes, :through => :page_elements, :source => :element, :source_type => 'Note'
has_many :files, :through => :page_elements, :source => :element, :source_type => 'File'
has_many :discussions, :through => :page_elements, :source => :element, :source_type => 'Discussion'
end
class PageElement < ActiveRecord::Base
belongs_to :page
belongs_to :element, :polymorphic => true
acts_as_list :scope => :page
end
class TodoList < ActiveRecord::Base
has_one :page_element, :as => :element
has_one :page, :through => :page_elements
end
class Note < ActiveRecord::Base
has_one :page_element, :as => :element
has_one :page, :through => :page_elements
end
class File < ActiveRecord::Base
has_one :page_element, :as => :element
has_one :page, :through => :page_elements
end
class Discussion < ActiveRecord::Base
has_one :page_element, :as => :element
has_one :page, :through => :page_elements
end