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 条件

相关推荐
czlczl200209252 小时前
告别 try-catch 地狱:Spring Boot 全局异常处理 (GlobalExceptionHandler) 最佳实践
java·spring boot·后端
Alair‎2 小时前
【无标题】
开发语言
Mr.Jessy5 小时前
JavaScript高级:构造函数与原型
开发语言·前端·javascript·学习·ecmascript
云栖梦泽7 小时前
鸿蒙应用签名与上架全流程:从开发完成到用户手中
开发语言·鸿蒙系统
爱上妖精的尾巴7 小时前
6-4 WPS JS宏 不重复随机取值应用
开发语言·前端·javascript
Goldn.8 小时前
Java核心技术栈全景解析:从Web开发到AI融合
java· spring boot· 微服务· ai· jvm· maven· hibernate
李慕婉学姐9 小时前
【开题答辩过程】以《基于Android的出租车运行监测系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·后端·vue
小鸡吃米…9 小时前
Python 列表
开发语言·python
m0_740043739 小时前
SpringBoot05-配置文件-热加载/日志框架slf4j/接口文档工具Swagger/Knife4j
java·spring boot·后端·log4j
编织幻境的妖9 小时前
SQL查询连续登录用户方法详解
java·数据库·sql