3

我有以下代码,我正在尝试使用 ElasticSearch 来查询它。

当我做 Book.search(:q=>'Foo') 时它可以工作,但当我做 Book.search(:author=>'Doctor') 时它不起作用。在我的数据库中,我有一个名称为“Barz,Foo,Doctor”的条目

我不确定在查询中是否应该使用术语或术语,因为我正在使用雪球破坏名称。我尝试了条款,然后出现错误。随着学期我没有得到任何结果。

class Author < ActiveRecord::Base
    has_many :books
end

class Book < ActiveRecord::Base
  belongs_to :author
  include Tire::Model::Search
  include Tire::Model::Callbacks
  mapping do
    indexes :title,
    indexes :description
    indexes :author,type: 'object', properties: {
         name: { type: 'multi_field',
                 fields: { name:  { type: 'string', analyzer: 'snowball' },
                           exact: { type: 'string', index: 'not_analyzed' } 
                  } 
          } }
  end

  def to_indexed_json
   to_json(:include=>{:author=>{:only=>[:name]}} )
  end

  def self.search(params = {})
    tire.search(load:true) do
      query do
       boolean do
        should { string params[:q] } if params[:q].present?
        should { term params[:author] } if params[:author].present?
       end
      end
      filter :term, :active=>true
    end
  end
end
4

2 回答 2

3

你可以这样做

should { terms :author, [params[:author]]} if params[:author].present?

或者

should { term :author, params[:author]} if params[:author].present?

或者

should { string "author:#{params[:author]}"} if params[:author].present?
于 2012-04-09T12:30:15.103 回答
0

正如@Karmi 所说,在此处输入链接描述

嗨,是的,你的方法似乎是一种。有几件事:*除非您想使用 Lucene 查询语法(增强、范围等),否则最好使用文本查询,* 是的,过滤器比查询更高效,示例中的 active=true 是非常适合过滤器。不过要注意查询、过滤器和构面之间的相互作用。但是,您对术语查询的定义不正确-应该是:

term :author, params[:author]
于 2012-04-09T22:20:27.920 回答