0

假设我有以下模型,并且我已使用sunspot_rails.

class Case < ActiveRecord::Base
  searchable do
  end
end

schema.xmlRails 中 Sunspot 的标准声明id为索引字段。当我使用 Web 界面访问 solr 和测试查询时,查询如下:

http://localhost:8982/solr/select/?q=id%3A%22Case+15%22&version=2.2&start=0&rows=10&indent=on

搜索Casesid等于Case 15工作正常并返回结果。

问题是当我在 rails 控制台中使用 Sunspot Rails 进行搜索时:

s = Case.search do 
    keywords('id:"Case 15"')
end

我得到:

=> <Sunspot::Search:{:fl=>"* score", :rows=>10, :start=>0, :q="id:\"Case 15\"", :defType=>"dismax", :fq=>["type:Case"]}>

这表明它正确输入:q了正确的查询值,但命中为 0:

s.hits

返回

=> []

如果我们假设它keywords不等效并且只搜索text字段(全文搜索)而不是冒号之前定义的字段:,那么我可以尝试以下操作:

s = Case.search do
  with(:id, "Case 15")
end

但这因太阳黑子异常而失败:

Sunspot::UnrecognizedFieldError: No field configured for Case with name 'id'

如何使用id模型的索引标准 solr/sunspot 字段进行搜索?

为了使问题更有用,我如何按 id 排序。以下不起作用:

s = Case.search do
  keywords("xxxx")
  order_by :id, :desc
end

不起作用。Sunspot::UnrecognizedFieldError: No field configured for Case with name 'id'

4

1 回答 1

4

您所说的 id 是 Sunspot 内部字段,不应直接使用。

为什么不添加自己的 id 字段(更改变量名称,以避免名称冲突):

class Case < ActiveRecord::Base
  searchable do
    integer :model_id {|content| content.id }
  end
end

接着

s = Case.search do
  keywords("xxxx")
  order_by :model_id, :desc
end

其他(凌乱的)选项是直接破解solr params

s = Case.search do
  keywords("xxxx")
  adjust_solr_params(:sort, 'id desc')
end
于 2011-08-24T16:58:41.653 回答