ElasticSearch的增删改查

ElasticSearch的增删改查

前言

使用elasticsearch6和kibana测试,官网直接下载解压就行。分别启动elasticsearch和kibana,启动完毕之后,在浏览器输入127.0.0.1:5601访问kibana。左侧菜单栏选择Dev Tools进到开发者模式。

一,document数据格式 面向文档的搜索分析引擎
  • 应用系统的数据结构都是面向对象的,复杂的

  • 对象数据存储到数据库中,只能拆解开来,变为扁平的多张表,每次查询的时候还得还原回对象格式,相当麻烦

  • ES是面向文档的,文档中存储的数据结构,与面向对象的数据结构是一样的,基于这种文档数据,ES可以提供复杂的索引,全文检索,分析聚合等功能。

  • ES的document用json数据格式来表达。

{
  "email":"zhangsan@sina.com", 
  "first_name":"san", 
  "last_name":"zhang",
 "info":{ 
   "bio":"curious and modest", 
   "age":30, 
   "interests":["bike","climb"] 
 }, 
   "join_data":"2019/8/1" 
}
二,电商网站商品管理案例背景介绍 有一个电商网站,需要为其基于ES构建一个后台系统,提供以下功能:
  • 对商品信息进行CRUD(增删改查)操作

  • 执行简单的结构化查询

  • 可以执行简单的全文检索,以及复杂的phrase(短语)检索

  • 对全文检索的结果,可以进行高亮显示

  • 对数据进行简单的聚合分析

三,简单的集群管理
  • 快速检查集群的健康状况 ES提供了一套api,叫做cat api,可以查看ES中各种各样 的数据
GET /_cat/healthy?v 

如何快速了解集群的健康状况?green,yellow,red green:每个索引的primary shard 和 replica shard都是active状态的 yellow:每个索引的primary shard都是active状态的,但是 部分 replica shard不是active状态,处于不可用状态 red:不是所有的primary shard都是active状态的,部分索引有数据丢失了 为什么会处于一个yellow状态? 我们现在就一个笔记本电脑,就启动了一个ES进程,相当于就只有一个node,现在ES中有一个index,就是kibana自己内置建立的index,由于默认的配置是给每个index分配5个primary shard和5个replica shard,而且primary shard 和 replica shard不能在同一台机器上,主要是为了容错,现在kibana自己建立的index是1个primary shard和1个replica shard,当前只有一个node,所以只有1个primary shard被分配了 和启动了,但是replica shard没有第二台机器去启动。

做一个实验,此时只要 启动第二个ES进程,就会在ES集群中有两个node,然后一个replica shrad就会自动分配过去,然后cluster status就会变成green状态。

  • .快速查看集群中有哪些索引
GET /_cat/indices?v 
  • 简单的索引操作 (下一篇文章介绍索引中mapping概念)

创建索引:

PUT /test_index?pretty 

删除索引:

DELETE /test_index?pretty
四,商品的CRUD操作
  • 新增商品:新增文档,建立索引

    PUT /index/type/id { "JSON数据" } 
    
    PUT test_index/test/1
    {
      "email":"zhangsan@sina.com", 
      "first_name":"san", 
      "last_name":"zhang",
     "info":{ 
       "bio":"curious and modest", 
       "age":30, 
       "interests":["bike","climb"] 
     }, 
       "join_data":"2019/8/1" 
    }
    
  • 查询商品:检索文档

    GET /index/type/id
    
    GET test_index/test/1
    
  • 修改商品:替换文档 必须带上所有的field

    PUT index/type/id {"json数据,包括所有字段的"}
    PUT test_index/test/1
    {
      "email":"lisi@sina.com", 
      "first_name":"si", 
      "last_name":"li",
     "info":{ 
       "bio":"java and python", 
       "age":25, 
       "interests":["swing","sing"] 
     }, 
       "join_data":"2019/9/1" 
    }
     
    
  • 修改商品:更新文档

    POST index/type/id/_update {"只写所需要更新的字段和数据"}
    
    POST test_index/test/1/_update
    {
      "doc": {
        "first_name":"si",
        "info":{ 
          "age":20
        }
      }
    } 
     
    
  • 删除商品:删除文档

    DELETE idnex/type/id?pretty
    
    DELETE test_index/test/1?pretty
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Elasticsearch是一个基于Lucene的全文搜索引擎,支持各种复杂查询,并提供实时索引、搜索功能。以下是关于在Elasticsearch中执行基本操作“增删改查”的简要介绍: ### **增加数据(Insert)** 在 Elasticsearch 中添加文档通常涉及创建一个新的索引文件,将数据作为 JSON 格式的文档插入到相应的索引中。 ```bash POST /my_index/_doc { "name": "John Doe", "age": 30, "occupation": "Engineer" } ``` 这将在名为 `my_index` 的索引下创建一个新的文档。 ### **删除数据(Delete)** 从 Elasticsearch 删除数据相对简单,需要指定文档的ID以及它所在的索引名称。 ```bash DELETE /my_index/_doc/1 ``` 这里的 `/1` 表示要删除索引 `my_index` 下 ID 为 `1` 的文档。 ### **修改数据(Update)** 更新文档可以覆盖整个文档,也可以仅更新部分字段。为了更新现有文档并保持其原始状态,可以使用 `_source` 参数。 ```bash PUT /my_index/_update/1?pretty { "doc" : { "age": 45 } } ``` 或者更详细地更新特定字段: ```bash PUT /my_index/_update/1?pretty { "script" : "_source.age = doc.age + 15" } ``` 这里使用了脚本语言来计算新年龄值。 ### **查询数据(Query)** 查询功能允许通过复杂的条件搜索文档,可以使用 DSL(Domain Specific Language)来进行。例如,查找所有年龄大于30的工程师: ```bash GET /my_index/_search { "query": { "bool": { "must": [ { "match": { "occupation": "Engineer" } }, { "range": { "age": { "gt": 30 } } } ] } } } ``` 这个查询返回了满足条件的所有文档。 ### 相关问题: 1. **如何优化 Elasticsearch 查询性能**? 2. **Elasticsearch 如何处理大数据量的实时搜索需求**? 3. **如何监控 Elasticsearch 集群的状态及性能指标**? 这四个问题涵盖了从基础操作到高级管理和优化的主题,深入探讨了如何更好地利用 Elasticsearch 解决实际的搜索和分析场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值