BoolQueryBuilder 如何进行模糊查询 并且模糊过滤去除name为Ab的 【4月更文挑战第2天】

简介: 如果你想使用 BoolQueryBuilder 进行模糊查询,并且要排除那些 name 字段为特定值(如 "Ab")的文档,你可以使用 must_not 子句与 FuzzyQueryBuilder 和 TermQueryBuilder 组合。以下是如何在 Elasticsearch 中实现这一需求的示例:Java代码实现假设你想对字段 description 进行模糊查询,并确保排除 name 字段为 "Ab" 的文档:javaCopy codeimport org.elasticsearch.index.query.BoolQueryBuilder;import org.e

如果你想使用 BoolQueryBuilder 进行模糊查询,并且要排除那些 name 字段为特定值(如 "Ab")的文档,你可以使用 must_not 子句与 FuzzyQueryBuilder 和 TermQueryBuilder 组合。以下是如何在 Elasticsearch 中实现这一需求的示例:

Java代码实现
假设你想对字段 description 进行模糊查询,并确保排除 name 字段为 "Ab" 的文档:

java

Copy code
import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;

// 创建 BoolQueryBuilder
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();

// 添加模糊查询
FuzzyQueryBuilder fuzzyQuery = QueryBuilders.fuzzyQuery("description", "searchTerm")
.fuzziness(Fuzziness.AUTO); // 自动设置模糊度
boolQuery.must(fuzzyQuery);

// 添加模糊排除过滤
TermQueryBuilder termQuery = QueryBuilders.termQuery("name.keyword", "Ab");
boolQuery.mustNot(termQuery); // 使用 mustNot 来排除具有特定 'name' 值的文档

// 执行查询
SearchResponse response = client.prepareSearch("your_index")
.setQuery(boolQuery)
.get();
代码解释
模糊查询 (FuzzyQueryBuilder): 对 description 字段应用模糊查询,可以捕获与 searchTerm 近似的词条。

排除特定字段值 (TermQueryBuilder): 使用 mustNot 子句结合 TermQueryBuilder 来排除那些 name 字段为 "Ab" 的文档。注意这里使用的是 name.keyword,这是假设 name 字段在映射中有一个未分词的 keyword 类型。如果没有,需要确认字段的确切映射类型。

组合查询 (BoolQueryBuilder): must 子句用来包含必须满足的模糊查询条件,而 mustNot 子句用于排除不想要的匹配条件。

通过上述设置,查询将返回那些 description 字段内容与 searchTerm 模糊匹配但 name 字段不是 "Ab" 的文档。这种查询可以有效地同时满足模糊搜索需求和特定排除条件。

相关文章
|
存储 JSON 网络协议
ElasticsearchRestTemplate客户端使用
ElasticsearchRestTemplate客户端使用
|
SQL 自然语言处理 Java
Springboot项目中使用Elasticsearch的RestClient
上一篇介绍了Elasticsearch的入门《5000字详说Elasticsearch入门(一)》,本篇介绍Springboot如何集成使用Elasticsearch。分为3步:配置properties文件、引入pom依赖、配置RestHighLevelClient类。
28869 1
|
10月前
|
存储 缓存 自然语言处理
Elasticsearch 查询性能优化:从 3 秒到 300ms 的 6 个核心参数调优指南
本文分享某电商平台 Elasticsearch 性能调优实战,通过调整分片数、刷新间隔、缓存配置等 6 个核心参数,将商品搜索从 3 秒优化至 300 毫秒,显著提升查询性能与系统吞吐量。内容涵盖性能诊断、参数调优逻辑、实操方案及避坑指南,助力高频查询场景下的 ES 优化。
|
12月前
|
JSON 安全 数据可视化
Elasticsearch(es)在Windows系统上的安装与部署(含Kibana)
Kibana 是 Elastic Stack(原 ELK Stack)中的核心数据可视化工具,主要与 Elasticsearch 配合使用,提供强大的数据探索、分析和展示功能。elasticsearch安装在windows上一般是zip文件,解压到对应目录。文件,elasticsearch8.x以上版本是自动开启安全认证的。kibana安装在windows上一般是zip文件,解压到对应目录。elasticsearch的默认端口是9200,访问。默认用户是elastic,密码需要重置。
5850 0
|
自然语言处理 数据挖掘 定位技术
深入探索Elasticsearch中的QueryBuilders
深入探索Elasticsearch中的QueryBuilders
1108 0
|
NoSQL 前端开发 Java
redis的发布/订阅(命令、普通工程、springboot实现)
小美老师给五年级三班上数学课的时候,实现给所在班级进行实时推送数学课程的活动(广播通信)
|
自然语言处理 达摩院 索引
Elasticsearch 中文分词器
在使用Elasticsearch 进行搜索中文时,Elasticsearch 内置的分词器会将所有的汉字切分为单个字,对用国内习惯的一些形容词、常见名字等则无法优雅的处理,此时就需要用到一些开源的分词器,以下分别介绍几种常见的中文分词器
11067 2
Elasticsearch 中文分词器
|
关系型数据库 MySQL 数据处理
Mysql关于同时使用Group by和Order by问题
总的来说,`GROUP BY`和 `ORDER BY`的合理使用和优化,可以在满足数据处理需求的同时,保证查询的性能。在实际应用中,应根据数据的特性和查询需求,合理设计索引和查询结构,以实现高效的数据处理。
1739 1
|
消息中间件 Java 关系型数据库
【二十】springboot整合ElasticSearch实战(万字篇)
【二十】springboot整合ElasticSearch实战(万字篇)
3964 47
|
NoSQL Redis
RedisTemplate.opsForHash()用法简介并举例
RedisTemplate.opsForHash()用法简介并举例
2309 1

热门文章

最新文章