使用Thinking Sphinx进行多个索引的全局搜索

时间:2012-04-26 09:52:28

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

我不想对一组类进行全局搜索,但是我想指定它应该使用的索引数组,这可能吗?我用谷歌搜索并尝试了不同的解决方案,但没有运气。

这可以正常工作(但对于一个索引)。

ThinkingSphinx.search "query", :classes => [Foo, Bar], :index => "my_foo_index"

这会引发错误:

ThinkingSphinx.search "query", :classes => [Foo, Bar], :index => "my_foo_index,my_bar_index"
> ThinkingSphinx::SphinxError: distributed index 'my_foo_index' in multi-index query found

就像这样:

ThinkingSphinx.search "query", :classes => [Foo, Bar], :index => ["my_foo_index", "my_bar_index"]
> NoMethodError: undefined method `force_encoding' for ["my_foo_index", "my_bar_index"]:Array

我还尝试将模型索引命名为相同,比如Foo模型和Bar模型上的“my_index”,但是在重建索引时我遇到了这个错误:

ERROR: section 'my_index_core_0' (type='source') already exists in /dev/config/development.sphinx.conf line 116 col 1.

我能想到的唯一解决方案是对每个模型进行多次搜索,然后合并结果。虽然我会在搜索中失去相关性,但这会有点震撼......

有什么想法吗?

1 个答案:

答案 0 :(得分:7)

尝试以下方法:

ThinkingSphinx.search 'query', :classes => [Foo, Bar],
  :index => 'my_foo_index_core,my_bar_index_core'

如果您有增量,请同时将my_foo_index_deltamy_bar_index_delta添加到列表中。这将避免分布式指数。