https://crate.io支持面(分面搜索)吗?
我在文件里什么都没找到。ElasticSearch 替换面片在2014年使用了集合体,但是机箱文档中的聚集段只讨论了SQL聚合函数。
我的用例:我有一个网站列表,每个记录都有一个域和一个语言字段。在显示搜索结果时,我希望获得搜索结果所显示的所有域的列表,以及所有语言的列表,并按出现的次数排序,以便缩小搜索结果的范围。还应给出这些单面值的结果数。
截图与面:

发布于 2017-06-28 07:16:24
发布于 2017-06-30 15:04:31
Crate不直接支持方面或弹性搜索聚合。正如您所建议的,您可以始终打开Elasticsearch。然而,还有其他方法来获得这些聚合。
1)您考虑过向集群发出多个查询吗?例如,如果使用Javascript动态加载页面,则可以首先返回搜索结果,然后加载方面。这也将减少应用程序的总体响应时间。
2)在CrateDB 2.1.x中,将支持子查询,这允许您在查询中包含方面:
select q1.id, q1.domain, q1.tag, q2.d_count, q3.t_count from websites q1,
(select domain, count(*) as d_count from websites where text like '%query%' group by domain) q2,
(select tag, count(*) as t_count from websites where text like '%query%' group by tag) q3
where q1.domain = q2.domain and q1.tag = q3.tag and q1.text like '%query%'
order by q1.id
limit 5;这给出了这样一个结果表,在该表中,搜索结果连同查询的域和标记计数一起使用:
+----+--------------+-----------+---------+-----------+
| id | domain | tag | d_count | t_count |
+----+--------------+-------------+---------+---------+
| 1 | example.com | example | 2 | 3 |
| 14 | crate.io | software | 1 | 4 |
| 17 | google.com | search | 5 | 2 |
| 29 | github.com | open-source | 3 | 3 |
| 47 | linux.org | software | 2 | 4 |
+----+--------------+-------------+---------+---------+免责声明:我刚接触过Crate :)
https://stackoverflow.com/questions/44758211
复制相似问题