ES 精准匹配 和 模糊查询的实现方式

这是比较复杂一点的示例:

复制代码
{
	"from": 0,
	"query": {
		"bool": {
			"minimum_should_match": "1",
			"must": [
				{
					"query_string": {
						"query": "status:0"
					}
				},
				{
					"query_string": {
						"query": "delFlag:0"
					}
				},
				{
					"terms": {
						"code.keyword": [
							"11016400",
							"11054600",
							"11010300",
							"11011400",
							"11001500"
						]
					}
				}
			],
			"should": [
				{
					"query_string": {
						"query": "shortName.keyword:*手机*"
					}
				},
				{
					"query_string": {
						"query": "code.keyword:*手机*"
					}
				}
			]
		}
	},
	"size": 10,
	"sort": [
		{
			"sortNum": {
				"order": "desc"
			}
		}
	]
}   

下面拆解一下功能:

复制代码
	"must": [
				{
					"query_string": {
						"query": "status:0"
					}
				},
				{
					"query_string": {
						"query": "delFlag:0"
					}
				},
				{
					"terms": {
						"code.keyword": [
							"11016400",
							"11054600",
							"11010300",
							"11011400",
							"11001500"
						]
					}
				}
			]

精准匹配 关键字说明

must 是必选满足该条件才能查询到数据

query_string 指定字段精准匹配

terms 相当于sql中的in查询 【code】是分片中的字段

复制代码
			"minimum_should_match": "1",
			"should": [
				{
					"query_string": {
						"query": "shortName.keyword:*手机*"
					}
				},
				{
					"query_string": {
						"query": "code.keyword:*手机*"
					}
				}
			]

模糊匹配 关键字说明

"minimum_should_match": "1" 表示 至少需要匹配一个 should 子句 才能返回文档。

查询逻辑

文档必须满足:

  1. 所有 must 条件(status:0, delFlag:0, code在指定列表中)

  2. 至少一个 should 条件(简称或编码包含"手机")

效果对比

  • 如果设为 0:即使不满足任何 should 条件,文档也会返回

  • 如果设为 2:必须同时满足两个 should 条件

  • 如果设为 1(当前):只需满足任意一个 should 条件

相关推荐
寻星探路31 分钟前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
lly2024062 小时前
Bootstrap 警告框
开发语言
2601_949146533 小时前
C语言语音通知接口接入教程:如何使用C语言直接调用语音预警API
c语言·开发语言
曹牧3 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
KYGALYX3 小时前
服务异步通信
开发语言·后端·微服务·ruby
zmzb01033 小时前
C++课后习题训练记录Day98
开发语言·c++
爬山算法4 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7254 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎4 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄4 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea