前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Elasticsearch DSL 基本语法

Elasticsearch DSL 基本语法

原创
作者头像
岳涛
发布2023-07-28 15:47:55
5750
发布2023-07-28 15:47:55
举报
文章被收录于专栏:大数据生态大数据生态

说明

本文描述问题及解决方法同样适用于 腾讯云 Elasticsearch Service(ES)

ES语法(DSL)简介

1. 全文检索

2. 查询指定字段

3. 排序

4. 分页查询

5. 多条件查询

6. 过滤器的使用

7. 聚合查询

写入语法

1 创建索引

1)创建一个索引(不指定分片和副本默认1个分片,一个副本)

代码语言:javascript
复制
PUT blog

2)创建一个指定分片和副本数量的索引 

代码语言:javascript
复制
PUT blog
{
  "settings":{
    "index":{
      "number_of_shards":5,
      "number_of_replicas":1
    }
  }
}

2 设置映射(定义字段类型)

代码语言:javascript
复制
PUT blog
{
  "mappings": {
    "properties": {
      "name": {
        "type": "text"
      },
      "content": {
        "type": "text"
      },
      "type": {
        "type": "keyword"
      }
    }
  }
}

3 写入数据

代码语言:javascript
复制
POST blog/_doc/1
{
  "name": "生蚝熟了之后还是生蚝吗",
  "content":"还是生蚝",
  "type":"科普"
}

查询语法

1 全文检索

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query":{
    "bool":{
      "should":[
        {
          "match":{
            "action":"dbcsyncservice/sync_diyring"
          }
        },
        {
          "match":{
            "retdesc":"成功7777"
          }
        }
      ]
    }
  }
}

hits:索引和文档的信息,以及最大分值,结果总数,然后就是具体的文档

2 查询指定字段

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query":{
    "match":{
      "action":"dbcsyncservice/sync_diyring"
    }
  },
  "_source":[
    "action",
    "respkg"
  ]
}

_source:指定字段

3 排序

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query": {
    "match": {
      "action": "dbcsyncservice/sync_diyring"
    }
  },
  "sort": [
    {
      "timespan.keyword": {
        "order": "desc"  
      }
    }
  ]
} 

order:desc降序,asc升序

4 分页查询

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query": {
    "match": {
      "action": "dbcsyncservice/sync_diyring"
    }
  },
  "sort": [
    {
      "timespan.keyword": {
        "order": "asc"
      }
    }
  ],
  "from": 0,  
  "size": 2    
}

from:从第几个开始

size:返回几个值

三种不同的分页方式:

  • from+size

优点:实现简单;缺点:深度分页的场景下,搜索性能低

  • scroll / search_after

优点:性能较高;缺点:实现相对复杂

5 布尔值(bool)查询,多条件查询

5.1 一个must

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query":{
    "bool":{
      "must":[
        {
          "match":{
            "action":"dbcsyncservice/sync_diyring"
          }
        },
        {
          "match":{
            "localip":"BJ01-DIY-SER03"
          }
        }
      ]
    }
  },
  "_source":[
    "action",
    "localip"
  ]
}

5.2 一个must_not

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query":{
    "bool":{
      "must_not":[
        {
          "match":{
            "action":"dbcsyncservice/sync_diyring"
          }
        }
      ]
    }
  },
  "_source":[
    "action",
    "localip"
  ]
}

5.3 must & must_not

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query": {
    "bool": {
      "must_not": [
        {
          "match": {
            "status": "success"
          }
        }
      ],
      "must": [
        {
          "match": {
            "action": "/Interfaces/userservice/v2/o_vrbt"
          }
           
        }
      ]
    }
  }
}

must:and关系,都要符合

should:or关系

must_not:一定不等于

6 过滤器的使用

代码语言:javascript
复制
GET monit-index-2020.07.21/_search
{
  "query":{
    "bool":{
      "must":[
        {
          "match":{
            "action":"dbcsyncservice/sync_diyring"
          }
        }
      ],
      "filter":{
        "range":{
          "port.keyword":{
            "gte":8899
          }
        }
      }
    }
  },
  "_source":[
    "action",
    "port"
  ]
}

查询action 是dbcsyncservice/sync_diyring的,并且端口是大于等于8899的文档

7 聚合查询

7.1 求总数

代码语言:javascript
复制
GET spcl-elastalert-01/_search
{
  "aggs": {
    "my_count": {
      "terms": {
        "field": "match_body.name.keyword",
        "size": 10
      }
    }
  }
}

7.2 聚合查询加时间范围

代码语言:javascript
复制
GET spcl-elastalert-01/_search
{
  "aggs": {
    "my_count": {
      "terms": {
        "field": "match_body.name.keyword",
        "size": 10
      }
    }
  },
  "query": {
    "bool": {
      "must": [
        {
          "range": {
            "@timestamp": {
              "gte": "now-7d",
              "lte": "now"
            }
          }
        }
      ]
    }
  }
}

7.3 聚合count告警的name,查询出其中告警数量最大的值

代码语言:javascript
复制
GET spcl-elastalert-01/_search
{
  "aggs": {
    "my_count": {
      "terms": {
        "field": "match_body.name.keyword",
        "size": 10
      },
      "aggs": {    
        "alert_max": {
          "max": {
            "field": "match_body.num_hits"
          }
        }
      }
    }
  },
  "query": {
    "bool": {
      "must": [
        {
          "range": {
            "@timestamp": {
              "gte": "now-7d",
              "lte": "now"
            }
          }
        }
      ]
    }
  }
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 说明
  • ES语法(DSL)简介
  • 写入语法
    • 1 创建索引
      • 2 设置映射(定义字段类型)
      • 3 写入数据
  • 查询语法
    • 1 全文检索
      • 2 查询指定字段
        • 3 排序
          • 4 分页查询
            • 5 布尔值(bool)查询,多条件查询
              • 5.1 一个must
              • 5.2 一个must_not
              • 5.3 must & must_not
            • 6 过滤器的使用
              • 7 聚合查询
                • 7.1 求总数
                • 7.2 聚合查询加时间范围
                • 7.3 聚合count告警的name,查询出其中告警数量最大的值
            相关产品与服务
            Elasticsearch Service
            腾讯云 Elasticsearch Service(ES)是云端全托管海量数据检索分析服务,拥有高性能自研内核,集成X-Pack。ES 支持通过自治索引、存算分离、集群巡检等特性轻松管理集群,也支持免运维、自动弹性、按需使用的 Serverless 模式。使用 ES 您可以高效构建信息检索、日志分析、运维监控等服务,它独特的向量检索还可助您构建基于语义、图像的AI深度应用。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档