【ES】---Aggregation聚合,遇到String类型如何分组

目录

一、左右模糊查询

在单纯搜索中,要达到左右模糊查询,可采用 fuzzyQuery: 左右模糊查询 【不分词,fuzziness的参数作用是在查询时,es动态的将查询关键词前后增加或者删除一个词,然后进行匹配】。

例如:

java 复制代码
FuzzyQueryBuilder fuzzyQueryBuilder = QueryBuilders.fuzzyQuery(fieldName, input).fuzziness(Fuzziness.ONE);
searchSourceBuilder.query(fuzzyQueryBuilder);

二、遇到string类型进行聚合分组

在一些聚合中,按照一定要求聚合,遇到string类型进行聚合分组。

2.1、string类型分组

如果是完整string类型分组:

java 复制代码
AggregationBuilder aggregationBuilder = AggregationBuilders.terms("group_by_extension")
        .script(new Script("doc['extension.keyword'].value.toUpperCase()")).size(Integer.MAX_VALUE);
//'extension是类型pdf,xlsx等
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
searchSourceBuilder.size(0);
searchSourceBuilder.query(boolQueryBuilder); //查询匹配条件
searchSourceBuilder.aggregation(aggregationBuilder); //分组聚合条件

2.2、Date类型(format)分组

java 复制代码
//由于(String类型)time存储形式是2023-07-23 00:00:06,而根据统计要求,按照月份维度进行统计,所以需要对create_time字段值进行转换下
AggregationBuilder aggregationBuilder = AggregationBuilders.terms("group_by_time")
        .script(new Script("doc['create_time.keyword'].value.substring(0, 7)")).size(Integer.MAX_VALUE);
相关推荐
青鱼入云1 小时前
ES索引配置字段解读
大数据·elasticsearch·搜索引擎
小牛马爱写博客1 小时前
ELK 企业级日志分析系统部署与实践
elk·elasticsearch·kibana·logstash
玥轩_5213 小时前
Git命令速查手册
大数据·git·elasticsearch·gitee·github·命令速查
Ribou4 小时前
Elasticsearch 9.2.0 三节点集群配置
大数据·elasticsearch·搜索引擎
Saintsafa4 小时前
centos安装ES
elasticsearch·centos
一叶飘零_sweeeet6 小时前
Linux 安装 Elasticsearch:避坑指南 + 性能调优实战
linux·运维·elasticsearch
勇往直前plus8 小时前
centos7利docker compose 快速部署 Elasticsearch + Kibana
elasticsearch·docker·jenkins
Elastic 中国社区官方博客19 小时前
通过混合搜索重排序提升多语言嵌入模型的相关性
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
liliangcsdn21 小时前
如何使用elasticdump进行elasticsearch数据还原
大数据·elasticsearch·搜索引擎
lijun_xiao20091 天前
elasticsearch学习笔记-02
笔记·学习·elasticsearch