思考狮身人面像并搜索多个模型

时间:2011-08-12 10:59:39

标签: ruby-on-rails sphinx thinking-sphinx

我正在寻找一种方法来对多个模型进行搜索(参见this post),并得到了几个答案,说思维狮身人面像会很适合这种事情。

事实上,它看起来很甜美,似乎应用程序范围的搜索功能(ThinkingSphinx.search)接近我想要的。但文档声明这将返回各种模型对象,具体取决于找到匹配的位置。

我的模特有点像这样:

  • 员工
  • 公司

员工仅通过公司与县相关联,公司又与市政府相关联,而市政当局则与实际县相关联。

现在作为搜索的结果,我真的只想要Employee对象。例如,搜索字符串“joe tulsa”应返回所有Employees,其中两个单词都可以在命名模型中的某处找到。我会得到一些误报,但至少我应该让每个名叫“乔”的员工都在塔尔萨县。

这可以通过Thinking Sphinx的内置功能实现吗?

1 个答案:

答案 0 :(得分:3)

我认为在这种情况下你应该做的是为你的Employee模型定义关联(你可能已经有过),例如:

class Employee < ActiveRecord::Base
  ...
  belongs_to :company
  has_one :municipality, :through => :company
  has_one :county, :through => :company
  ...
end

class Company < ActiveRecord::Base
  ...
  belongs_to :municipality
  has_many :employees
  has_one :county, :through => :municipality
  ...
end

class Municipality < ActiveRecord::Base
  ...
  belongs_to :county
  has_many :companies
  ...
end

class County < ActiveRecord::Base
  ...
  has_many :municipalities
  ...
end

编辑:我测试了多级has_one关系,但它不能像那样工作。在没有非规范化的情况下对这4层进行建模似乎相当复杂。如果我拿出一些东西,我会更新。在任何情况下,如果您将非规范化(即向所有模型添加冗余外部ID到您的employees表),则关联很简单,并且您会大量增加索引生成时间。同时,它可能涉及更多的工作以确保一致性。

设置关联后,您可以在Employee模型中定义Sphinx索引,如下所示:

define_index do
  indexes :name, :sortable => :true
  indexes company(:name),      :as => :company
  indexes municipality(:name), :as => :municipality
  indexes county(:name),       :as => :county
  ...
end

这样,关联中的列也会被编入索引,Sphinx会在构建索引时自动将所有这些表连接在一起。