ElasticSearch的基本原生操作

本文详细介绍了如何使用 Elasticsearch 进行索引查询、全量及主键查询、文档修改与删除,以及各种条件查询,包括分页、排序、多条件组合查询和范围查询。此外,还涉及到了高亮显示和完全匹配等高级搜索技巧,是 Elasticsearch 操作的实用教程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

可以用postman 我这里用kibana执行的命令 把index换成自己的就可以了 es版本7.8.0

查询所有索引

GET  /_cat/indices?v

全部查询

GET /fei_index/_search
或
GET /fei_index/_search
{
  "query": {
    "match_all": {
      
    }
  }
}

主键查询

GET /fei_index/_doc/1

全量修改
版本号加一

GET /fei_index/_doc/1
{       
 "name": "小米",
  "age": 22
}

删除

DELETE  /fei_index/doc/1

条件查询

GET /fei_index/_search?q=name:张
或
GET /fei_index/_search
{
  "query": {
    "match": {
      "name": "张三"
    }
  }
}

分页查询

GET /fei_index/_search
{
  "query": {
    "match_all": {
      
    }
  },
  "from": 0,
  "size": 2
}

求分页 (页码-1)*每页数据条数
查询所有 每个数据只显示 age

GET /fei_index/_search
{
  "query": {
    "match_all": {
      
    }
  },
  "from": 0,
  "size": 2,
   "_source": ["age"]
 
}

排序查询

GET /fei_index/_search
{
  "query": {
    "match_all": {
      
    }
  },
  "from": 0,
  "size": 2,
   "_source": ["age"],
   "sort": [
     {
       "age": {
         "order": "desc"        //排序 
       }
     }
   ]
 
}

多条件查询 多个条件全部成立
must

GET /fei_index/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match": {
            "age": "22"
          }
        },
        {
          "match": {
            "name": "张三"
          }
        }
      ]
    }
  }
}

多条件查询 其中一个条件成立即可

should

GET /fei_index/_search
{
  "query": {
    "bool": {
      "should": [
        {
          "match": {
            "age": "22"
          }
        },
        {
          "match": {
            "name": "小米"
          }
        }
      ]
    }
  }
}

范围查询

gt大于

gte大于等于

GET /fei_index/_search
{
  "query": {
    "bool": {
      "should": [
        {
          "match": {
            "age": "22"
          }
        },
        {
          "match": {
            "name": "小米"
          }
        }
      ],
      "filter": [
        { 
          "range": {
            "age": {
              "gte": 10,
              "lte": 20
            }
          }
        }
      ]
    }
  }
}

完全匹配

match查询会进行分词 如果不想要分词我们需要完全匹配

GET  /fei_index/_search
{
  "query": {
    "match_phrase": {
      "name": "张三"
    }
  }
}

高亮显示

把查询出来的name字段进行高亮显示

GET  /fei_index/_search
{
  "query": {
    "match_phrase": {
      "name": "张三"
    }
  },
  "highlight": {
    "fields": {
      "name": {}
    }
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值