ES高级查询语法DSL实战 - 第504篇

历史文章(文章累计500+)

国内最全的Spring Boot系列之一

国内最全的Spring Boot系列之二

国内最全的Spring Boot系列之三

国内最全的Spring Boot系列之四

国内最全的Spring Boot系列之五》

国内最全的Spring Boot系列之六

国内最全的Spring Boot系列之七》

ElasticSearch重建/创建/删除索引操作 - 第501篇

ElasticSearch文档操作[ES系列] - 第502篇

ElasticSearch文档批量操作[ES系列] - 第503篇

Hi,大家好,我是悟纤。我就是我,不一样的烟火。我就是我,与众不同的小苹果。

这一节来看看ES高级查询Query DSL。

一、DSL语法和数据准备

ES中提供了一种强大的检索数据方式,这种检索方式称之为Query DSL (Domain Specified Language 领域专用语言) , Query DSL是利用Rest API传递JSON格式的请求体(RequestBody)数据与ES进行交互,这种方式的丰富查询语法让ES检索变得更强大,更简洁。

1.1 语法

基本语法如下:

复制代码
GET /es_db/_doc/_search {json请求体数据}可以简化为下面写法GET /es_db/_search {json请求体数据}​

1.2 示例

示例如下:

复制代码
#无条件查询,默认返回10条数据GET /es_db/_search{  "query":{    "match_all":{}  }}​

(1)took:花费时间,单位毫秒。

(2)hits:符合条件的信息。

(3)hits.total:符合条件的总文档。

(4)hits.hits:符合条件结果集,默认前10个文档。

1.3 示例数据

准备数据:

复制代码
#指定ik分词器PUT /es_db{"settings" : {"index" : {"analysis.analyzer.default.type": "ik_max_word"}}}​# 创建文档,指定idPUT /es_db/_doc/1{"name": "张三","sex": 1,"age": 25,"address": "广州天河公园","remark": "java developer"}PUT /es_db/_doc/2{"name": "李四","sex": 1,"age": 28,"address": "广州荔湾大厦","remark": "java assistant"}​PUT /es_db/_doc/3{"name": "王五","sex": 0,"age": 26,"address": "广州白云山公园","remark": "php developer"}​PUT /es_db/_doc/4{"name": "赵六","sex": 0,"age": 22,"address": "长沙橘子洲","remark": "python assistant"}​PUT /es_db/_doc/5{"name": "张龙","sex": 0,"age": 19,"address": "长沙麓谷企业广场","remark": "java architect assistant"}​PUT /es_db/_doc/6{"name": "赵虎","sex": 1,"age": 32,"address": "长沙麓谷兴工国际产业园","remark": "java architect"}​PUT /es_db/_doc/7{"name": "李虎","sex": 1,"age": 32,"address": "广州番禺节能科技园","remark": "java architect"}​PUT /es_db/_doc/8{"name": "张星","sex": 1,"age": 32,"address": "武汉东湖高新区未来智汇城","remark": "golang developer"}​

二、match_all查询

2.1 match_all

使用match_all,匹配所有文档,默认只会返回10条数据。

原因:_search 查询默认采用的是分页查询,每页记录数size的默认值为10。如果想显示更多数据,指定size

复制代码
GET /es_db/_search# 等同于GET /es_db/_search{"query":{"match_all":{}}}​

2.2 返回源数据_source

_source 关键字: 是一个数组,在数组中用来指定展示那些字段

复制代码
GET /es_db/_search{"query": {"match_all": {}},"_source": ["name","address"]}​#在查询中过滤#不查看源数据,仅查看元字段GET /es_db/_search{"_source": false,"query": {"match_all": {}}}​#只看以obj.开头的字段GET /es_db/_search{"_source": "obj.*","query": {"match_all": {}}}​

2.3 返回指定条数size

size 关键字: 指定查询结果中返回指定条数。默认返回值10条。

复制代码
get /es_db/_search{  "query":{    "match_all": {}  },  "size":2}​

2.4 分页查询from&size

size:显示应该返回的结果数量,默认是 10

from:显示应该跳过的初始结果数量,默认是 0

from 关键字用来指定起始返回位置,和size关键字连用可实现分页效果

复制代码
{  "query":{    "match_all": {}  },  "from": 0,  "size":2}​

2.5 指定字段排序sort

注意:会让得分失效。

复制代码
get /es_db/_search{  "query":{    "match_all": {}  },  "sort":{    "age":"desc"  }}​

我就是我,是颜色不一样的烟火。
我就是我,是与众不同的小苹果。

à悟纤学院:https://t.cn/Rg3fKJD

学院中有Spring Boot 相关的课程!点击「阅读原文」进行查看!

SpringBoot视频:http://t.cn/A6ZagYTi

SpringBoot交流平台:https://t.cn/R3QDhU0

SpringSecurity5.0视频:http://t.cn/A6ZadMBe

ShardingJDBC分库分表:http://t.cn/A6ZarrqS

分布式事务解决方案:http://t.cn/A6ZaBnIr

JVM内存模型调优实战:http://t.cn/A6wWMVqG

Spring入门到精通:https://t.cn/A6bFcDh4

大话设计模式之爱你:https://dwz.cn/wqO0MAy7

相关推荐
智算菩萨4 小时前
高效多模态大语言模型:从统一框架到训练与推理效率的系统化理论梳理
大数据·人工智能·多模态
hzp6664 小时前
新兴存储全景与未来架构走向
大数据·大模型·llm·aigc·数据存储
QT 小鲜肉4 小时前
【Linux命令大全】001.文件管理之git命令(实操篇)
linux·服务器·笔记·git·elasticsearch
INFINI Labs5 小时前
Easy-Es 2.1.0-easysearch 版本发布
大数据·elasticsearch·搜索引擎·easysearch·easy-es
小北方城市网5 小时前
第 6 课:Vue 3 工程化与项目部署实战 —— 从本地开发到线上发布
大数据·运维·前端·ai
落叶,听雪6 小时前
AI建站推荐
大数据·人工智能·python
lhrimperial6 小时前
Elasticsearch核心技术深度解析
大数据·elasticsearch·搜索引擎
geneculture6 小时前
从智力仿真到认知协同:人机之间的价值对齐与共生框架
大数据·人工智能·学习·融智学的重要应用·信智序位
无代码专家7 小时前
设备巡检数字化闭环解决方案:从预防到优化的全流程赋能
大数据·人工智能
神算大模型APi--天枢6468 小时前
合规与高效兼得:国产全栈架构赋能行业大模型定制,从教育到工业的轻量化落地
大数据·前端·人工智能·架构·硬件架构