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

这篇具有很好参考价值的文章主要介绍了Elastic Stack--04--ES中的检索方式、Query DSL。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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


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

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

第二种方式

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

GET bank/_search

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.Query DSL

2.1 基本语法

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

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.2 match

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

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

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.3 match_phrase

将需要匹配的值当成一个整体单词(不分词)进行检索,短语匹配
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.4 multi_match[多字段匹配]

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.5 bool[复合查询]

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

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

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

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.6 filter[结果过滤]

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

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据

2.7 term

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

Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据
Elastic Stack--04--ES中的检索方式、Query DSL,常用数据库,elasticsearch,jenkins,大数据文章来源地址https://www.toymoban.com/news/detail-842081.html

到了这里,关于Elastic Stack--04--ES中的检索方式、Query DSL的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Elastic Stack 8.11:引入一种新的强大查询语言 ES|QL

    作者:Tyler Perkins, Ninoslav Miskovic, Gilad Gal, Teresa Soler, Shani Sagiv, Jason Burns Elastic® Stack 8.11 引入了数据流生命周期、一种配置数据流保留和降采样(downsampling) 的简单方法(技术预览版),以及有关 Kibana® Inspector 中跨集群搜索响应的详细信息以及重新路由摄取处理器(reroute i

    2024年02月03日
    浏览(52)
  • 【ElasticSearch-基础篇】ES高级查询Query DSL全文检索

    和术语级别查询(Term-Level Queries)不同,全文检索查询(Full Text Queries)旨在 基于相关性搜索和匹配文本数据 。这些查询会对输入的文本进行分析,将其 拆分 为词项(单个单词),并执行诸如分词、词干处理和标准化等操作。 全文检索的关键特点: 对输入的文本进行分析

    2024年01月22日
    浏览(51)
  • ES delete_by_query条件删除的几种方式

     es 查询删除的几种方式 1.根据id删除 2.根据多个id删除 3.根据多个id范围删除 注意:删除完成后,执行以下脚本回收索引空间 curl -XPOST http://127.0.0.1:9200/indexname/_forcemerge?max_num_segments=1 

    2024年02月09日
    浏览(40)
  • Elastic Stack(1):Elastic Stack简介

    1 简介 ELK是一个免费开源的日志分析架构技术栈总称,官网https://www.elastic.co/cn。包含三大基础组件,分别是Elasticsearch、Logstash、Kibana。但实际上ELK不仅仅适用于日志分析,它还可以支持其它任何数据搜索、分析和收集的场景,日志分析和收集只是更具有代表性。并非唯一性。

    2024年01月19日
    浏览(49)
  • Kibana-elastic--Elastic Stack--ELK Stack

    Kibana 是什么? | Elastic 将数据转变为结果、响应和解决方案 使用 Kibana 针对大规模数据快速运行数据分析,以实现可观测性、安全和搜索。对来自任何来源的任何数据进行全面透彻的分析,从威胁情报到搜索分析,从日志到应用程序监测,不一而足。 虫瞻图(英语:worm\\\'s-eye

    2024年02月15日
    浏览(40)
  • Elastic Stack 8.0 安装 - 保护你的 Elastic Stack 现在比以往任何时候都简单

    在 8.0 中,我们很高兴为所有用户带来简化的安全功能。 从 7.1 开始,我们向所有人免费提供了确保 Elastic Stack 安全所需的所有功能。 然而,我们知道设置安全性并不好玩,你需要专注于你的项目目标。 好消息给你! 从 8.0 开始,自管理集群默认启用 Elastic Stack 安全性,配置

    2023年04月08日
    浏览(41)
  • Elastic:使用 Docker 安装 Elastic Stack 8.x 并开始使用

    Elastic Stack 8.0 终于于最近发布了。在我之前的文章 “Elastic Stack 8.0 安装 - 保护你的 Elastic Stack 现在比以往任何时候都简单” 我已经详细地描述了如何在本地部署 Elasticsearch 及 Kibana。设置 Elasticsearch 的最简单方法是使用 Elastic Cloud 上的 Elasticsearch Service 创建托管部署。 如果你

    2024年02月16日
    浏览(35)
  • Elastic Stack 环境配置与框架简介

    目录 简介 什么是Elastic Stack Elasticasearch Logstash Kibana Beats 框架图 下载 配置 一、安装java环境 启动 Elasticsearch Kibana FileBeat Logstash 测验 Elastic Stack 缩写为elk,它由三个软件组成: Elasticsearch 、 Logstash 、 Kibana ,因此缩写为elk,随着版本的变化,添加了一个新软件 Beats ,因此其全

    2024年02月12日
    浏览(46)
  • 运用 Elastic Stack 收集 docker 容器日志

    Elastic Stack 在收集日志方面有很多的方面的应用。在今天的文章中,我将使用 docker 来安装 Elastic Stack。我将演示如何使用 docker 安装 Filebeat 并收集容器的日志。 在我之前的文章 “Beats:为 Filebeat 配置 inputs”,我展示了如何使用 Filebeat 来收集 container 里的日志数据。在那篇文

    2023年04月08日
    浏览(35)
  • Elastic(ELK) Stack 架构师成长路径

    Elastic Stack(ELK Stack)是一个开源的日志分析平台,由 Elasticsearch、Logstash 和 Kibana 三个组件组成,主要用于数据搜索、分析和可视化。要成为一名 ELK Stack 架构师,需要遵循一定的成长路径,以便逐步掌握相关知识和技能。 基本了解:在这个阶段,您需要学习基本的ELK Stack概

    2023年04月21日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包