Ransack搜索关联并拒绝



我使用的是transak,我有一个Venue模型,它与阶段(草稿、编辑、完成等)有多对多的关系。

这是我的表格

= search_form_for @q, url: search_admin_venues_path, html: {method: :post} do |f|
  = f.label :name_cont
  = f.text_field :name_cont
  = f.select :stages_id_eq, Stage.all.collect{|c| [c.name, c.id]}, {include_blank: true}

有没有办法搜索不属于选定舞台的场地?以某种方式拒绝他们?

这是我使用的洗劫搜索

  def search
    @q = Venue.search(params[:q])
    @venues = @q.result(distinct: true)    
    render :index
  end

这是我过去常做的事情:

stage_obj = Stage.find_by_name(params[:stage])
@venues = Venue.all.includes(:stages).reject{|v| v.stages.include?(stage_obj)}

使用not_eq谓词应该有效,正如Viren在评论中注意到的那样。

= f.select :stages_id_not_eq, Stage.all.collect{|c| [c.name, c.id]}, {include_blank: true}

您还可以使用多选输入和in/not_in谓词来包含或排除多个值。

最新更新