太阳黑子和高级关联搜索



我的应用程序具有并属于许多SpecificationsMachines

class Machine < ActiveRecord::Base
  has_and_belongs_to_many :specs

规格具有field(宽度、重量、容量、马力)和value属性。

搜索完全通过Solr通过太阳黑子完成。

我希望能够根据其规格找到一台机器,例如查找宽度大于 50 的所有机器。

我知道我可以分别索引spec_fieldspec_value,但它会过滤值超过 50 的规格,其中可能包括我不想要的字段,例如高度或容量(因此搜索宽度> 50 将在结果中产生容量> 50)。

理想情况下,我想将机器的每个规格及其值分配给其自己的索引字段,以便我的索引具有"高度"或"重量"等字段,但规格是灵活的,有些机器有一组规格,而另一台机器有不同的规格集,所以看起来它不能解决。

甚至可以用Solr完成吗?

找到的解决方案

我找到的解决方案是使用此处描述的"动态字段"

索引

dynamic_integer :specs do
  specs.inject({}) do |hash,spec|
    hash.merge(spec.spec_field.label.to_sym => spec.value)
  end
end

查询

  dynamic :specs do
    if params[:specs].present?
      for spec in params[:specs]
        case spec[:condition]
          when "gt"
            with(spec[:field]).greater_than(spec[:value])
          when "lt"
            with(spec[:field]).less_than(spec[:value])
          else
            with(spec[:field],spec[:value])
        end
      end
    end
  end

SOLR对我来说越来越好!

您可以构造一个方法,该方法为指定的数字范围和字符串值返回 TRUE,然后为该布尔值编制索引。

def width_greater_than_50
  (field == "width") && (value > 50)
end

然后,您将符号:width_greater_than_50作为要索引的内容传递。

最新更新