Elastic Stack--04--ES中的检索方式、Query DSL

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 1.ES中的检索方式
    • 第一种方式
        • [GET bank/_search # 检索bank下的所有信息,包括 type 和 docs](# 检索bank下的所有信息,包括 type 和 docs)
        • [GET bank/_search?q=*&sort=account_number:asc](#GET bank/_search?q=*&sort=account_number:asc)
    • 第二种方式
        • [GET bank/_search](#GET bank/_search)
  • [2.Query DSL](#2.Query DSL)
      • [2.1 基本语法](#2.1 基本语法)
      • [2.2 match](#2.2 match)
      • [2.3 match_phrase](#2.3 match_phrase)
      • [2.4 multi_match多字段匹配](#2.4 multi_match[多字段匹配])
      • [2.5 bool复合查询](#2.5 bool[复合查询])
      • [2.6 filter结果过滤](#2.6 filter[结果过滤])
      • [2.7 term](#2.7 term)

1.ES中的检索方式

在ElasticSearch中支持两种检索方式

  1. 通过使用REST request URL 发送检索参数(uri+检索参数)
  2. 通过使用 REST request body 来发送检索参数 (uri+请求体)

第一种方式

GET bank/_search # 检索bank下的所有信息,包括 type 和 docs
GET bank/_search?q=*&sort=account_number:asc

第二种方式

通过使用 REST request body 来反射检索参数 (uri+请求体)

GET bank/_search


2.Query DSL

2.1 基本语法

  ElasticSearch提供了一个可以执行的JSON风格的DSL(domain-specific language 领域特定语言),这个被称为Query DSL,该查询语言非常全面,并且刚开始的时候感觉有点复杂,真正学好它的方法就是从一些基础案例开始的。


2.2 match

  上面我们用到来的match_all是匹配所有的数据,而我们现在要讲的match是条件匹配

如果对应的字段是基本类型(非字符串类型),则是精确匹配。




2.3 match_phrase

将需要匹配的值当成一个整体单词(不分词)进行检索,短语匹配

2.4 multi_match多字段匹配


2.5 bool复合查询

布尔查询又叫组合查询,bool用来实现复合查询,

bool把各种其它查询通过 must(与)、must_not(非)、should(或)的方式进行组合

复合语句可以合并任何其他查询语句,包括复合语句也可以合并,了解这一点很重要,这意味着,复合语句之间可以相互嵌套,可以表达非常复杂的逻辑。


2.6 filter结果过滤

  并不是所有的查询都需要产生分数,特别是那些仅用于"filtering"的文档,为了不计算分数,ElasticSearch会自动检查场景并且优化查询的执行。


2.7 term

  和match一样,匹配某个属性的值,全文检索字段用match,其他非text字段匹配用term



相关推荐
极创信息1 小时前
Linux挖矿病毒深度清理实战教程,从进程隐藏、Rootkit驻留到彻底根除
java·大数据·linux·运维·安全·tomcat·健康医疗
SEO_juper1 小时前
Semrush 蓝海关键词筛选,AI 一键拓展完整词库
大数据·谷歌·seo·geo·gemini·询盘·b2b
未若君雅裁3 小时前
日志采集与ELK:从本地日志到集中检索分析
运维·elk·jenkins
阿 才3 小时前
跟文件系统(busybox)的构建
大数据·hadoop·分布式
宁波鹿语心理3 小时前
过度卷入的三角化:养育者情感投射对青少年自我边界形成的结构性影响及干预路径
大数据
逐米时代3 小时前
制造型企业AI智能体实施步骤详解:提升协同效率的实战指南
大数据·人工智能
大嘴皮猴儿4 小时前
跨境电商运营笔记:我是如何用工具解决多语言素材问题的
大数据·人工智能·新媒体运营·自动翻译·教育电商
赤龙ERP4 小时前
赤龙一周观察 · 6月第2周
大数据·人工智能·ai·erp
JGDT_4 小时前
ERP重塑与未来趋势:SAP的实践及大一统格局(上)
大数据·人工智能·安全·架构·开源
ACP广源盛139246256735 小时前
IX7008 PCIe 交换芯片@ACP#RTX Spark 经济型 8 口扩展芯片(对比 ASM1806)
大数据·人工智能·分布式·嵌入式硬件·gpt·spark·电脑