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

相关推荐
周杰伦fans20 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
许彰午21 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
Bat U1 天前
JavaEE|多线程初阶(七)
java·开发语言
谭欣辰1 天前
C++ 排列组合完整指南
开发语言·c++·算法
foundbug9991 天前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
XDH_CS1 天前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql
小短腿的代码世界1 天前
Qt实时盈亏计算深度解析:从持仓数据到动态盈亏展示
开发语言·qt
小康小小涵1 天前
基于ESP32S3实现无人机RID模块底层源码编译
linux·开发语言·python
lzjava20241 天前
Python的函数
开发语言·python