【ES】---field、field.keyword的区别

目录

一、说明

ElasticSearch5.x以上版本使用text和keyword作为字符串类型取代之前版本的string类型。新版本字符串将默认被同时映射成text和keyword类型。

字符串(text) :用于全文索引,该类型的字段将通过分词器进行分词,最终用于构建索引;
字符串(keyword):不分词,只能搜索该字段的完整的值,用于精准匹配过滤和聚合;

-----备注说明:

一般Boolean、数值类型不需要分词;

另外,Date类型特殊,如果加上 @JSONField(name = "file_upload_time", format = "yyyy-MM-dd HH:mm:ss"),表明将Date按照format形式转换了,因此在查询时为了不分词,需要加上keyword;

二、代码示例

java 复制代码
BoolQueryBuilder boolQueryBuilder = new BoolQueryBuilder()
        .must(QueryBuilders.termQuery("delete", Boolean.FALSE)) //Boolean类型
        .must(QueryBuilders.termQuery("sid", 1111L))  //Long类型
        .must(QueryBuilders.existsQuery("type.relegation_id")) //type为数组,relegation_id为string
        .mustNot(QueryBuilders.termQuery("type.relegation_id.keyword", ""))
.must(QueryBuilders.rangeQuery("create_time.keyword").from("2022-01-01 00:00:01").to("2023-07-23 00:00:06")); //create_time是Date类型,加了format

StatsAggregationBuilder metricAggre = AggregationBuilders.stats("metric").field("file_size");
AggregationBuilder subAgg = AggregationBuilders.terms("group_by_extension")
        .script(new Script("doc['w_extension.keyword'].value.toUpperCase()")).size(Integer.MAX_VALUE);
subAgg.subAggregation(metricAggre);
AggregationBuilder aggregationBuilder = AggregationBuilders.terms("group_by_base_id").field("type.relegation_id.keyword").size(Integer.MAX_VALUE);
aggregationBuilder.subAggregation(subAgg);
相关推荐
闲人编程13 小时前
Elasticsearch搜索引擎集成指南
python·elasticsearch·搜索引擎·jenkins·索引·副本·分片
先跑起来再说14 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
Dxy123931021615 小时前
深度解析 Elasticsearch:从倒排索引到 DSL 查询的实战突围
大数据·elasticsearch·搜索引擎
Dxy123931021617 小时前
别再让 ES 把你拖垮!5 个实战技巧让搜索性能提升 10 倍
大数据·elasticsearch·搜索引擎
星辰_mya1 天前
Elasticsearch线上问题之OOM
大数据·elasticsearch·搜索引擎
Elastic 中国社区官方博客1 天前
使用 Groq 与 Elasticsearch 进行智能查询
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
张彦峰ZYF1 天前
一套「策略化 Elasticsearch 召回平台」架构设计思路
大数据·elasticsearch·搜索引擎
Dxy12393102162 天前
Elasticsearch 索引与映射:为你的数据打造一个“智能仓库”
大数据·elasticsearch·搜索引擎
倒流时光三十年2 天前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
星辰_mya2 天前
Elasticsearch更新了分词器之后
大数据·elasticsearch·搜索引擎