Elasticsearch:DSL Query

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

Query DSL的分类

Elasticsearch提供了基于JSON的DSL(Domain Specific Language)来定义查询。常见的查询类型包括:

  • 查询所有:查询出所有的数据,一般测试用,例如:match_all,但有分页限制,一次20条左右
  • 全文检索(full text)查询:利用分词器对用户输入内容分词,然后去倒排索引库中匹配。常见的有两种
    • match_query
    • multi_match_query
  • 精确查询:根据精确词条值查找数据,一般查找keyword、数值、日期、boolean等类型字段。(不需要分词,整体做倒排索引)
    • ids (按照id查询)
    • range (按照数值范围查询)
    • term (按照数据的值查询)
  • 地理(geo)查询:根据经纬度查询,例如:
    • geo_distance
    • geo_bounding_box
  • 复合(compound)查询:符合查询可以将上述各种查询条件组合起来,合并查询条件
    • bool
    • function_score

DSL Query基本语法
查询的基本语法如下:

GET /indexName/_search
{
  "query":{
    "查询类型":{
      "查询条件":"条件值"
    }
  }
}

查询所有

GET /indexName/_search
{
  "query":{
    "match_all":{
    }
  }
}

全文检索查询

全文检索查询会对用户输入内容分词,常用于搜索框搜索

  • match查询:全文检索查询的一种,会对用户输入内容分词,然后去倒排索引库检索。
    语法
GET /indexName/_search
{
  "query":{
    "match":{
      "字段":"搜索的内容"
    }
  }
}

实例

GET /es_test/_search
{
  "query":{
    "match":{
      "name.lastName":"张"
    }
  }
}

结果

{
  "took" : 5,
  "timed_out" : false,
  "_shards" : {
    "total" : 1,
    "successful" : 1,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    "total" : {
      "value" : 1,
      "relation" : "eq"
    },
    "max_score" : 0.2876821,
    "hits" : [
      {
        "_index" : "es_test",
        "_type" : "_doc",
        "_id" : "1",
        "_score" : 0.2876821,
        "_source" : {
          "info" : "测试es",
          "email" : "xxx@163.com",
          "name" : {
            "firstName" : "三",
            "lastName" : "张"
          },
          "age" : 16
        }
      }
    ]
  }
}

查询所有

GET /es_test/_search
{
  "query":{
    "match":{
      "all":"张"
    }
  }
}
  • multi_match:与match查询类似,允许同时查询多个字段,即从对应的字段中查询匹配的内容。参与查询字段越多,查询性能越差,建议使用copy_to将多个要查的字段copy到一个字段。
    语法
GET /indexName/_search
{
  "query":{
    "mutil_match":{
      "query":"要查询的内容",
      "fields":["字段1","字段2"]
    }
  }
}

精确查询

精确查询一般是查找keyword、数值、日期、boolean等类型字段。所以不会对搜索条件分词。
常见的有:

  • term:根据词条精确值查询
    语法
GET /indexName/_search
{
  "query":{
    "term":{
      "FIELD":{
        "value":"VALUE"
      }
    }
  }
}

例子

GET /es_test/_search
{
  "query":{
    "term":{
      "age":{
        "value":"16"
      }
    }
  }
}
  • range:根据值的范围查询
    语法
GET /indexName/_search
{
  "query":{
    "range":{
      "FIELD":{
        "gte":10,
        "lte":20
      }
    }
  }
}

例子

GET /es_test/_search
{
  "query":{
    "range":{
      "age":{
        "gte":10,
        "lte": 20
      }
    }
  }
}

地理查询

根据经纬度查询,常见的使用场景:查询附近的酒店,查询附近的出租车,搜索附近的人

  • geo_bounding_box:查询geo_point值落在某个矩形范围的所有文档
GET /indexName/_search
{
  "query": {
    "geo_bounding_box":{
      "FIELD1":{
        "top_left":{
          "lat":31.1,
          "lon":121.5
        }
      },
      "FIELD2":{
        "bottom_right":{
          "lat":30.9,
          "lon":121.7
        }
      }
    }
  }
}
  • geo_distance:查询到指定中心点小于某个距离值的所有文档
GET /indexName/_search
{
  "query": {
    "geo_distance":{
      "distance":"15km",
      "FIELD":"31.21,121.5"
    }
  }
}

复合查询

复合(compound)查询,可以将其他简单查询组合起来,实现更复杂的搜索逻辑,例如:

  • function score:算分函数查询,可以控制文档相关性算分,控制文档排名。例如百度竞价

相关性打分算法
当我们利用match查询时,文档结果会根据与搜索词条的关联度打分(_score),返回结果时按照分值降序排列。
Elasticsearch:DSL Query
Elasticsearch:DSL Query
Elasticsearch:DSL Query
使用function score query,可以修改文档的相关性算分(query score),根据新得到的算分排序。

GET /indexName/_search
{
  "query": {
    "function_score": {
      "query": {"match": {"all": "外滩"} // 原始查询条件,搜索文档并根据相关性打分(query score)
    },
    "functions": [
        {
          "filter": {"term":{"id": "1"}}, //过滤条件,符合条件的文档才会被重新算分
          "weight":10 //算分函数,算分函数的结果称为function score,将来会与query score运算,得到新分数,常见的算分函数有:weight:给一个常量值,作为函数结果(function score);field_value_factor:用文档中的某个字段值作为函数结果;random_score:随机生成一个值,作为函数结果;script_score:自定义计算公式,公式结果作为函数结果
        }
      ]
    },
    "boost_mode":"multiply"//加权模式,定义function score与query score的运算方式,包括:multiply:两者相乘,默认就是这个;replace:用function score替换query score;其他:sum,avg,max,min
  }
}
  • 布尔查询,是一个或多个查询子句的组合。子查询的组合方式有:
  • must:必须匹配每个子查询,类似"与"
  • should:选择性匹配子查询,类似"或"
  • must_not:必须不匹配,不参与算分,类似"非"
  • filter:必须匹配,不参与算分
GET /indexName/_search
{
  "query": {
    "bool": {
      "must": [
        {"term": {"city": "上海"}}
      ],
      "should": [
       {"term": {"brand": "皇冠假日"}},
       {"term": {"brand": "华美达"}}
      ], 
      "must_not": [
        {"range": {"price": {"lte": 500}}}
      ],
      "filter": [
        {"range": {"score": {"gte": 45}}}
      ]
    }
  }
}

Reference
黑马程序员文章来源地址https://www.toymoban.com/news/detail-498096.html

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

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

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

相关文章

  • 一起学Elasticsearch系列-Query DSL

    本文已收录至Github,推荐阅读 👉 Java随想录 微信公众号:Java随想录 DSL是Domain Specific Language的缩写,指的是为特定问题领域设计的计算机语言。这种语言专注于某特定领域的问题解决,因而比通用编程语言更有效率。 在Elasticsearch中,DSL指的是Elasticsearch Query DSL,是一种以J

    2024年02月01日
    浏览(52)
  • elasticsearch 笔记二:搜索DSL 语法(搜索API、Query DSL)

    从索引 tweet 里面搜索字段 user 为 kimchy 的记录 从索引 tweet,user 里面搜索字段 user 为 kimchy 的记录 从所有索引里面搜索字段 tag 为 wow 的记录 说明:搜索的端点地址可以是多索引多 mapping type 的。搜索的参数可作为 URI 请求参数给出,也可用 request body 给出 URI 搜索方式通过 URI

    2024年02月04日
    浏览(39)
  • ElasticSearch 高级查询语法Query DSL实战

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

    2024年02月07日
    浏览(36)
  • 【ElasticSearch系列-03】ElasticSearch的高级句法查询Query DSL

    ElasticSearch系列整体栏目 内容 链接地址 【一】ElasticSearch下载和安装 https://zhenghuisheng.blog.csdn.net/article/details/129260827 【二】ElasticSearch概念和基本操作 https://blog.csdn.net/zhenghuishengq/article/details/134121631 【二】ElasticSearch的高级查询Query DSL https://blog.csdn.net/zhenghuishengq/article/details/1

    2024年02月06日
    浏览(46)
  • 2.ElasticSearch 高级查询语法Query DSL实战

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

    2024年03月15日
    浏览(39)
  • 【ES专题】ElasticSearch 高级查询语法Query DSL实战

    个人在学习的过程中,感觉比较吃力的地方有如下: 语法结构比较陌生 没有中文文档, 只能看英文 其他博客也比较少介绍语法结构。比如说,为什么查询中会出现 query 有ES入门基础,且想进一步学习ES基本操作的朋友 系列上一篇文章:《【ES专题】ElasticSearch快速入

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

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

    2024年01月22日
    浏览(42)
  • 15.Elasticsearch 7.15 Query DSL 之 Wildcard查询、Regexp查询

    返回包含与通配符模式匹配的文档。 以下搜索返回 user.id 字段包含以 ki 开头并以 y 结尾的文档。这些匹配项可以包括 kiy、kity 或 kimchy (必填, 对象) 你想查询的字段 参数名 描述 boost (Optional, float) 用于降低或提高查询相关性得分的浮点数。默认为1.0。 rewrite (可选,字符串)

    2023年04月08日
    浏览(34)
  • 【ElasticSearch-基础篇】ES高级查询Query DSL术语级别查询并结合springboot使用

    Elasticsearch 提供了基于 JSON 的完整 Query DSL(Domain Specific Language)来定义查询。 因Query DSL是利用Rest API传递JSON格式的请求体(RequestBody)数据与ES进行交互,所以我们在使用springboot的时候也可以很方便的进行集成,本文主要讲述的就是使用springboot实现各类DSL的语法查询。 Elastics

    2024年02月01日
    浏览(39)
  • Elastic Stack--04--ES中的检索方式、Query DSL

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 在ElasticSearch中支持两种检索方式 通过使用REST request URL 发送检索参数(uri+检索参数) 通过使用 REST request body 来发送检索参数 (uri+请求体) GET bank/_search # 检索bank下的所有信息,包括 type 和 docs GET bank/_sea

    2024年03月21日
    浏览(35)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包