我的应用程序具有并属于许多Specifications
的Machines
class Machine < ActiveRecord::Base
has_and_belongs_to_many :specs
规格具有field
(宽度、重量、容量、马力)和value
属性。
搜索完全通过Solr通过太阳黑子完成。
我希望能够根据其规格找到一台机器,例如查找宽度大于 50 的所有机器。
我知道我可以分别索引spec_field
和spec_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
作为要索引的内容传递。