sunspot-solr中的数量统计: facet

在使用solr过后,各种搜索都会变快很多,而solr却不怎么支持统计功能,只找到一个数量的统计,facet,简单的用法相当于:

select count(id) count,category_id value from project_categories group by category_id
# 对应solr查询及使用
search = ProjectCategory.solr_search do
# limit默认是100,也就是说默认返回100条记录,设置成-1则返回所有记录
facet :category_id ,limit:-1
end
search.facet(:category_id).rows.each{|x|puts "category_id:#{x.value} count: #{x.count}"}

search里面可以跟正常solr搜索一样附加很多条件比如:

with :stage , 2
with(:published_at).less_than_or_equal_to Time.parse('2015-1-1')
# 等等……

facet也可以分组数组模式的参数,例如project的索引是这么建的:

integer :category_ids ,:multiple=>true do
categories.map(&:id)
end
# 也就是说每个project会对应多个category_id 也可以这么搜索:
search = ProjectCategory.solr_search do
facet :category_ids ,limit:-1
end
# 跟上面一样的用法
search.facet(:category_ids).rows.each{|x|puts "category_id:#{x.value} count: #{x.count}"}

而如果我只需要返回特定的几种类别数据,比如只要类别1,2,3的数据。
直接在search里面加条件是不行的,因为solr的数据结构不像数据库的sql那样,如果加上with :category_ids ,[1,2,3] 所表达的意思是:先找出包含1或2或3的project,再执行这些project的所有category_ids的group by,得不到想要的结果,可以这么写:

facet :category_ids ,limit:-1 , only: [1,2,3]
# 可以解释为最终只取类别1,2,3的项目数量

更多solr文档参见: https://github.com/sunspot/sunspot/blob/master/README.md

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,890评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,947评论 6 342
  • # 一度蜜v3.0协议 --- # 交互协议 [TOC] ## 协议说明 ### 请求参数 下表列出了v3.0版协...
    c5e350bc5b40阅读 668评论 0 0
  • 文/小太阳下的乌龟 一、 三星为什么会下跪呢? 为了祭祖,跪跪无妨;有人为三星抛头颅,洒热血,英勇牺牲,跪跪无妨。...
    小太阳下的乌龟阅读 3,103评论 20 23
  • 医生给我倒了杯咖啡。“最近医药费涨得有点快哈~ 下个月会有返券”
    U0阅读 298评论 0 1