2

我正在使用 Sunspot Solr 进行多面搜索。但是,在尝试显示按所需顺序排序的构面值时,我遇到了问题。我的产品的尺码可能是(S、M、L、XL、XXL),有些产品的尺码可能是鞋码(8、9、10、11、12、13)。当将 facet.sort 方法设置为 'index' 时,它会将字符串值按字母顺序排列,从而分别产生 [L, M, S, XL, XXL] 和 [10, 11, 12, 8, 9]。实现自定义排序方法以实现这些目标的好方法是什么?

我的控制器:

@search = Product.search do
    fulltext params[:search]
    facet(:size, :sort => :index)
    with(:size, params[:size]) if params[:size].present?
end

我的观点:

<% for row in @search.facet(:brand).rows %>
    <li>
        <% if params[:brand].blank? %>
            <%= link_to link_to "#{row.value} (#{row.count})", params.merge({:brand => row.value}) %>
        <% else %>
            <strong><%= row.value %></strong> (<%= link_to "remove", params.merge({:brand => nil}) %>)
        <% end %>
    </li>
<% end %>

显示的结果排序

   SIZE 
L (10)
M (10)
S (10)
XL (10)
XXL (10)
4

1 回答 1

4

正如您所提到的,Solr 只接受两个方面的排序值,计数(结果数)和索引(字典序)。假设您不想更改索引数据,您有两种选择,手动排序 facets 数组,或创建自定义查询 facet。我会选择前者,因为您的方面结果集非常有限。

手动排序

# supposing these are your possible sizes
SCALE = %w(S M L XL XXL) 
# once you perform your search sort based on the scale order
@search.facet(:size).rows.sort_by! { |r| SCALE.index(r.value) }

查询方面

@search = Product.search do
  fulltext params[:search]
  facet(:size) do
    row('S') { with(:size, 'S') }
    row('M') { with(:size, 'M') }
    row('L') { with(:size, 'L') }
    row('XL') { with(:size, 'XL') }
    row('XXL') { with(:size, 'XXL') }
  end
  with(:size, params[:size]) if params[:size].present?
end
于 2013-08-20T21:45:06.930 回答