【HBZ分享】ES中的DLS命令使用

2023-11-05 18:52
文章标签 es 使用 命令 分享 hbz dls

本文主要是介绍【HBZ分享】ES中的DLS命令使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ES中常见的DLS关键字及命令的使用案例

  1. match:匹配关键字,包含分词的模糊匹配,以及精准匹配
title: 字段的名称, elasticsearch要查的内容,即查询title中带有elasticsearch的文档
GET /索引库名/_search 
{"query": {"match": {"title": "elasticsearch"}}
}
  1. term:用于精确匹配一个指定字段的关键词,不进行分词处理。
category: 字段的名称, books要查的内容, 即查询category = books的文档
GET /索引库名/_search 
{"query": {"term": {"category": "books"}}
}
  1. match_all: 全量查询,一般很少用,所有数据全都查出来
match_all后面的大括号就这么写就行,啥也不需要加
GET /shop_v1/_search
{"query": {"match_all": {}}
}

es中的分页 以及 范围查询

  1. gte:大于等于

  2. gt:大于

  3. lte:小于等于

  4. lt:小于

范围擦汗寻, 查询price在5-10之间的数据
GET /shop_v1/_search
{"query": {"range": {"price": {"gte": 5,"lte": 100}}}
}
分页查询, size = 每次查询的条数, from = 从第几条开始查
GET /shop_v1/_search
{"size": 10,"from": 0,"query": {"match_all": {}}
}

ES中的排序

  1. 通过sort字段,desc 与 esc分别是降序 与 升序
使用key = sort, 根据price进行esc升序排序
GET /shop_v1/_search
{"size": 10,"from": 0,"sort": [{"price": "asc"}],"query": {"match_all": {}}
}

ES的布尔查询

  1. "must"关键字用于指定必须匹配的条件,即所有条件都必须满足

  2. "must_not"关键字指定必须不匹配的条件,即所有条件都不能满足

  3. "should"关键字指定可选的匹配条件,即至少满足一个条件

格式:
{"query": {"bool": {"must": [// 必须匹配的条件],"must_not": [// 必须不匹配的条件],"should": [// 可选匹配的条件],"filter": [// 过滤条件]}}
}
案例: 查询,summary字段中,必须包含Cloud的内容(因为是match分词匹配), 【并且】price的范围必须 >= 5
GET /shop_v1/_search
{"query": {"bool": {"must": [{ "match": { "summary": "Cloud" }},{ "range": { "price": { "gte": 5 }}}]}}
}

ES中的filter过滤

  1. filter可以缓存查询数据,达到搞笑
  2. 可以对 【数字范围】,【日期范围】,【布尔逻辑】,【存在性检测】进行操作
term查询过滤器, 过滤出category = books的数据,完全匹配,因为term是精准匹配的key
GET /product/_search
{"query": {"bool": {"filter": {"term": {"category": "books"}}}}
}
range查询过滤器,过滤出price在30-50之间的数据
GET /product/_search
{"query": {"bool": {"filter": {"range": {"price": {"gte": 30,"lte": 50}}}}}
}

== 总节: 其实使用filter 和 直接使用range差范围是一致的,只不过filter下面可以同时使用range 与 term等==

ES中的match多字段匹配 和 短语搜索

  1. 多字段搜索使用:multi_match
  2. 短语搜索使用:match_phrase
  3. 短语搜索会考虑到短语间多个词语的顺序,比如搜 iPhone 32G, 那么就会把文档中带有【iPhone 32G】的搜索出来,只有iPhone 或 只有32G的数据都是不能搜出来的,又有iPhone 32G在一起的才会被搜索
多字段搜索使用:multi_match
query = 要搜索的关键词, fields = 该关键词出现的字段都要搜出来
含义:搜索出product_name, description这俩字段中,包含iPhone的文档, 两个字段为OR关系,只要iPhone这个词存在于其中一个字段那么就会被搜索
GET /product_v2/_search
{"query": {"multi_match": {"query": "iPhone","fields": ["product_name", "description"]}}
}
query:需要匹配的查询文本。
fields:一个包含需要进行匹配的字段列表的数组。
短语搜索使用:match_phrase, 搜索description字段中,带有classic noval的文档, 必须classic noval这个顺序,这个词组才行,缺一个词,或顺序不对都不能搜出来
GET /product_v2/_search
{"query": {"match_phrase": {"description": "classic novel"}}
}
match例子
match搜索,会进行分词, 即把classic novel分词,只要description带有classic 或者 novel的都能搜出,这个是match
GET /product_v2/_search
{"query": {"match": {"description": "classic novel"}}
}

ES的fuzzy日常拼错矫正查询

  1. fuzzy可以自动矫正简单的拼错,比如日常中一个单词,某两个字母写反了,或者漏写了等简单的失误,fuzzy都可以矫正
  2. 但精准度可能比较低,并且比较耗费CPU
  3. fuzzy模糊查询是根据编辑距离来模糊匹配的
  4. 编辑距离指的是:
    (1). 更改字符(box→fox)
    (2). 删除字符(black→lack)
    (3). 插入字符(sic→sick)
    (4). 转置两个相邻字符(dgo→dog)
  5. fuzzy不会进行分词
  6. 模糊度fuzziness: 0,1,2,auto, 其中auto是单词超过5个字符,默认设置为2。小于2个字符,默认设置为0
# 指定模糊度2,更松散匹配, 比如要查询包含cloud的文档,但少写了两个字母,写成了clo, 设置模糊度为2,则可以自动匹配上
-查询summary字段中,包含cloud的文档,输入的查询值为clo, 模糊度设置2
GET /shop_v1/_search
{"query": {"fuzzy": {"summary": {"value": "clo","fuzziness": "2"}}}
}# 指定模糊度1,更严格匹配, 同样搜cloud,但写成了clo, 由于少了两个字母,模糊度为2,但实际设置是1,所以距离不够,无法检索到内容
- 查询summary字段中,包含cloud的文档,输入的查询值为clo, 模糊度设置1
GET /shop_v1/_search
{"query": {"fuzzy": {"summary": {"value": "clo","fuzziness": "1"}}}
}# 使用自动检查,1个单词拼写错误, auto自动设置模糊度,当大于5个字符会默认自动设置模糊度为2, 当小于2个字符,会自动设置模糊度为0
查询summary字段中,包含spring的文档,输入的查询成了Springa, 模糊度设置auto, 由于spring大于5,所以模糊度为2
GET /shop_v1/_search
{"query": {"fuzzy": {"summary": {"value": "Sprina","fuzziness": "auto"}}}
}

ES的高亮显示

  1. 基本用法: 在 key = highlight 里面填写要高亮显示的字段,可以填写多个字段,并且高亮的部分就是关键字,在搜出来的文档中,查询输入的内容会是高亮的。
  2. 高亮显示是通过标签包裹匹配的文本来实现的,通常是 或其他 HTML 标签,当然可以修改这个标签,下面有例子
  3. pre_tags, post_tags是前后置标签,就是改变高亮的样式,默认是, 可以通过这两个去替换em标签,比如用font来替换
查询出 title字段包含【java】 或者 content字段包含【老王】的文档, 并且高亮显示出title, content中的搜索关键字, 关键字高亮的样式设置为<font color='yellow'> java </font> 这种的,不使用默认的<em>
GET /high_light_test/_search
{"query": {"bool": {"should": [{"match": {"title": "java"}},{"match": {"content": "老王"}}]}},"highlight": {"pre_tags": "<font color='yellow'>","post_tags": "</font>","fields": [{"title":{}},{"content":{}}]} 
}

这篇关于【HBZ分享】ES中的DLS命令使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/351831

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他