繁体   English   中英

Rails ElasticSearch Tire - 同时过滤多个参数的嵌套字段

[英]Rails ElasticSearch Tire - filter nested field on multiple parameters the same time

我有一个电影模型和一个具有电影类型方面的搜索页面。 可以选择搜索页面上每个方面附近的复选框。 我将检查的方面术语列表传递给控制器​​,并且我想过滤电影集合以仅包括那些使用复选框选择了类型的电影。

我的索引和搜索定义模型是:

class Movie < ActiveRecord::Base
  include Tire::Model::Search
  include Tire::Model::Callbacks

  mapping do
    indexes :id,           :index    => :not_analyzed
    indexes :title,        :analyzer => 'snowball', :boost => 100
    indexes :description,  :analyzer => 'snowball'
    indexes :genres do
      indexes :title, analyzer: 'keyword'
    end
  end

  def to_indexed_json
    to_json( include: { genres: { only: [:title, :id] } } )
  end

  def self.search(params={})
    tire.search(page: params[:page], per_page: 5, load: false) do
      query do
        all
        #boolean do
        #  must { string params[:query], :default_field => 'title' }
        #end
      end


      #filter 'genres.title', :values => params[:genres] if params[:genres].present?
      filter :terms, 'genres.title' => ['Genre 1', 'Genre 2', 'Genre 3']


      facet 'global-genres', global: true do
        terms 'genres.title', size: 15
      end
      facet 'scoped-genres' do
        terms 'genres.title', size: 15
      end
    end
  end

  attr_accessible :description, :title, :year, :genres

  has_and_belongs_to_many :genres, :uniq => true

end

我不确定这部分应该如何重写:

#filter 'genres.title', :values => params[:genres] if params[:genres].present?
filter :terms, 'genres.title' => ['Genre 1', 'Genre 2', 'Genre 3']
#filter 'genres.id', :values => [1, 2, 3]

稍后,我将把流派列表或流派 ID 作为参数传递,我需要对它们进行过滤。

filter :terms, 'genres.title' => ['Genre 1', 'Genre 2', 'Genre 3']

它过滤到具有“流派 1”或“流派 2”或“流派 3”的电影,我需要这些流派具有 AND 逻辑。

我怎样才能正确地做到这一点?

您需要使用execution: 'and'设置过滤器。 我已将此作为示例添加Tyre集成测试套件中:

s = Tire.search('articles-test') do
  query { all }
  filter :terms, :tags => ['ruby', 'python'], :execution => 'and'
end

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM