ES 查询用法

一,基本查询语法

通过ES查询表达式(Query DSL),可以实现复杂的查询功能,ES查询表达式主要由JSON格式编写,可以灵活的组合各种查询语句。

提示:这里先介绍基本的语法结构,后续单独讲解具体的查询语法。

1,查询基本语法结构

GET /{
   索引名}/_search
{
   
        "from" : 0,  // 返回搜索结果的开始位置
        "size" : 10, // 分页大小,一次返回多少数据
        "_source" :[ ...需要返回的字段数组... ],
        "query" : {
    ...query子句... },
        "aggs" : {
    ..aggs子句..  },
        "sort" : {
    ..sort子句..  }
}

还支持一次搜索多个索引

GET /order1,order2/_search

按前缀匹配索引名

GET /order*/_search

查询结果格式

{
   
  "took" : 5, // 查询消耗时间,单位毫秒 
  "timed_out" : false, // 查询是否超时
  "_shards" : {
    // 本次查询参与的ES分片信息,查询中参与分片的总数,以及这些分片成功了多少个失败了多少个
    "total" : 1,
    "successful" : 1,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    // hits字段包含我们搜索匹配的结果
    "total" : {
    // 匹配到的文档总数
      "value" : 1, // 找到1个文档
      "relation" : "eq"
    },
    "max_score" : 1.0, // 匹配到的最大分值
    "hits" : [ 
         // 这里就是我们具体的搜索结果,是一个JSON文档数组
    ]
  }
}

2.query子句

query子句主要用来编写类似SQL的Where语句,支持布尔查询(and/or)、IN、全文搜索、模糊匹配、范围查询(大于小于)。

3.aggs子句

aggs子句,主要用来编写统计分析语句,类似SQL的group by语句

4.sort子句

sort子句,用来设置排序条件,类似SQL的order by语句

5.ES查询分页

ES查询的分页主要通过from和size参数设置,类似MYSQL 的limit和offset语句

例子:

GET /order_v2/_search
{
   
  "from": 0,
  "size": 20, 
  "query": {
   
    "match_all": {
   }
  
  • 28
    点赞
  • 142
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
ElasticsearchES)提供了多种查询方式,可以根据不同的需求和场景选择合适的查询类型。常用的ES查询方式包括: 1. Match Query(匹配查询):根据指定的字段和值进行全文匹配查询。可以使用match查询来搜索包含指定词条的文档。 2. Term Query(精确查询):根据指定的字段和精确值进行查询。term查询是在某个字段中寻找包含精确值的文档。 3. Range Query(范围查询):根据指定字段和范围值进行查询。可以使用range查询来搜索在指定范围内的文档。 4. Bool Query(布尔查询):将多个查询条件进行逻辑组合,可以使用must、must_not、should等关键词来组合查询条件。 5. Wildcard Query(通配符查询):使用通配符模式进行匹配查询。可以使用通配符(*和?)来匹配文档中的一部分内容。 6. Fuzzy Query(模糊查询):根据指定的值进行模糊匹配查询。可以使用fuzzy查询来搜索与指定值相似的文档。 以上是一些常用的Elasticsearch查询方法,可以根据具体需求选择合适的查询方式来进行数据检索。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Elasticsearch的多种查询方式](https://blog.csdn.net/weixin_42039228/article/details/131513436)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [spring 操作elasticsearch查询使用方法](https://download.csdn.net/download/weixin_38631960/12780046)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值