• ElasticSearch - 索引库和文档相关命令操作


    目录

    一、ElasticSearch 索引库操作

    1.1、mapping 属性

    1.2、索引库相关操作

    1.2.1、创建索引库

    1.2.2、增加和删除索引库

    1.2.3、修改索引库

    1.3、文档操作

    1.3.1、添加文档

    1.3.2、文档的查询和删除

    1.3.3、修改文档

    1.全量修改:会先删除旧文档,添加新文档.

    2. 增量修改:修改执行字段值.

    如果通过 PUT 进行全量修改的文档和原来的文档不一样,会发生什么? 


    一、ElasticSearch 索引库操作


    1.1、mapping 属性

    mappinig 是对索引库中文档的约束,常见的 mapping 属性如下:

    • type:表示字段数据类型,常见的类型如下
      • 字符串:text(可以进行分词的文本)、keyword(精确值,不用进行分词的文本.  例如:国家名、品牌、公司名、ip 地址......).
      • 数值:long、integer、short、byte、double、float
      • 布尔:boolean
      • 日期 date
      • 对象:object
    • index:是否创建索引。默认 true.
    • analyzer:使用那种分词器进行分词(比如之前所说的 IK 分词器).
    • properties:该字段的子字段.

    例如如下:

    1. PUT /heima
    2. {
    3.   "mappings": {
    4.     "properties": {
    5. //这里是自定义的 info 信息
    6.       "info":{
    7.         "type""text", //表示 info 中的信息可以进行分词.
    8.         "analyzer""ik_smart" //使用 IK 分词器分词
    9. //这里没有定义 index ,表示默认为词条创建索引
    10.       },
    11.       "email":{
    12.         "type""keyword", //表示 email 不需要分词,是一个关键字
    13.         "index""false" //不创建索引
    14.       },
    15. "createTime": {
    16. "type": "date", //时间类型
    17. "format": "yyyy-MM-dd HH:mm:ss", //约定时间格式
    18. "index": false
    19. },
    20.       "name":{
    21.         "properties": {
    22.           "firstName": {
    23.             "type""keyword"
    24.           }
    25.         }
    26.       },
    27. // ......
    28.     }
    29.   }
    30. }

    1.2、索引库相关操作

    1.2.1、创建索引库

    ES 中通过 Restful 请求操作索引库、文档.  请求的内容用 DSL 语句来表示.

    创建 索引库 和 mapping 的语法如下:

    1. PUT /索引库名称
    2. {
    3.   "mappings": {
    4.     "properties": {
    5.       "字段名":{
    6.         "type""text",
    7.         "analyzer""ik_smart"
    8.       },
    9.       "字段名2":{
    10.         "type""keyword",
    11.         "index""false"
    12.       },
    13. "字段名3": {
    14. "type": "date", //时间类型
    15. "format": "yyyy-MM-dd HH:mm:ss", //约定时间格式
    16. "index": false
    17. },
    18.       "字段名4":{
    19.         "properties": {
    20.           "子字段": {
    21.             "type""keyword"
    22.           }
    23.         }
    24.       },
    25. // ...略
    26.     }
    27.   }
    28. }

    假设创建以下索引库

    1. PUT /userinfo
    2. {
    3.   "mappings": {
    4.     "properties": {
    5.       "info":{
    6.         "type""text",
    7.         "analyzer""ik_smart"
    8.       },
    9.       "email":{
    10.         "type""keyword",
    11.         "index""false"
    12.       },
    13.       "name":{
    14.         "properties": {
    15.           "firstName": {
    16.             "type""keyword"
    17.           }
    18.         }
    19.       }
    20.     }
    21.   }
    22. }

    1.2.2、增加和删除索引

    查看索引库语法:

    GET/索引库名
    

    示例:

    GET /userinfo

    删除索引库的语法:

    DELETE /索引库名

    示例:

    DELETE /userinfo

    删除后再 GET 就会发现找不到该索引库,如下

    1.2.3、修改索引

    索引库和 mapping 一旦创建就无法修改,只可以再原来的基础上新增字段.

    语法如下:

    1. PUT /索引库名/_mapping
    2. {
    3.   "properties": {
    4.     "新字段名":{
    5.       "type""integer"
    6.     }
    7.   }
    8. }

    实例如下:

    1. PUT /userinfo/_mapping
    2. {
    3.   "properties": {
    4.     "age":{
    5.       "type""integer"
    6.     }
    7.   }
    8. }

    例如这里我先创建 userinfo 索引库.

    接着新增 age 字段:

    接着查询 userinfo 索引库

    如果是 PUT 的是存在的字段呢,比如 age,将 type 改为 keyword,他就会告诉你 mapper 中 integer 类型不可以修改成 keyword.

    1.3、文档操作

    1.3.1、添加文档

    这里就类似于 mysql 中向表中添加数据一样,需要先创建表,后向添加数据.

    文档操作也是如此,需要先创建索引库,然后才能添加文档.

    添加文档语法如下:

    1. POST /索引库名/_doc/文档id
    2. {
    3.     "字段1""值1",
    4.     "字段2""值2",
    5.     "字段3": {
    6.         "子属性1""值3",
    7.         "子属性2""值4"
    8.     },
    9. // ...
    10. }

    示例如下:

    1. POST /userinfo/_doc/1
    2. {
    3.     "info""大家好,我是练习了两年半的偶像练习生",
    4.     "email""cxk@itcast.cn",
    5.     "name": {
    6.         "firstName""c",
    7.         "lastName""xk"
    8.     }
    9. }

    假设创建以下索引库:

    下面添加文档:

    •  _index:表示你是向哪个索引库添加文档.
    • _type:表示类型添加的是什么类型,_doc 表示文档.
    • _id:是添加文档的指定的 id.
    • version:这是一个版本号,基于自旋锁实现的版本号,这个每对这个文档进行一次操作,版本号 就会 + 1.
    • result:created 表示创建成功.

    1.3.2、文档的查询和删除

    查询文档语法:

    GET /索引库名/_doc/文档id 

    示例:

    GET /userinfo/_doc/1 
    

    删除文档语法:

    DELETE /索引库名/_doc/文档id 
    

    示例:

    DELETE /userinfo/_doc/1 

    1.3.3、修改文档

    修改文档有两种方式

    1.全量修改:会先删除旧文档,添加新文档.

    语法如下:

    1. PUT /索引库名/_doc/文档id
    2. {
    3.     "字段1""值1",
    4.     "字段2""值2",
    5. // ... 略
    6. }

    示例如下:

    1. PUT /userinfo/_doc/1
    2. {
    3.     "info""我是练习两年半的偶像练习生",
    4.     "email""cxk@itcast.cn",
    5.     "name": {
    6.         "firstName""c",
    7.         "lastName""xk"
    8.     }
    9. }

    例如原来存在以下文档

    现在 PUT 以下操作

    然后 GET 查询就是修改后的文档

    2. 增量修改:修改执行字段值.

    主要注意 索引名后面是 _update 

    语法如下:

    1. POST /索引库名/_update/文档id
    2. {
    3.     "doc": {
    4. "字段名""新的值",
    5. }
    6. }

    示例如下:

    1. POST /userinfo/_update/1
    2. {
    3.   "doc": {
    4.     "email""ZhaoYun@itcast.cn"
    5.   }
    6. }

    假设原本有文档如下

    修改 info 字段的值,如下

    通过 GET 获取文档

    如果通过 PUT 进行全量修改的文档和原来的文档不一样,会发生什么? 

    例如存在以下文档

    这里新增字段 age ,结果如下

    实际上,这里 es 的处理方式,就是按照 “删除旧文档,新增新文档” 的操作来修改文档的.

  • 相关阅读:
    昇思MindSpore携手宝兰德推出智慧工地解决方案,助力工地安全生产管理领域数智化升级
    Python文件操作
    本地Java代码打成镜像提交到K8S部署
    C++:写二进制文件(附完整源码)
    React TypeScript 定义组件的各种方式
    罗技驱动默认安装位置介绍
    炒现货黄金怎么做?挖掘黄金的投资机会
    [机缘参悟-66]:深度思考-吃苦、努力、勤奋的方式与本质
    SpringCloudAlibaba分布式流量控制组件Sentinel实战与源码分析-中
    如何提取视频中的音频转为mp3
  • 原文地址:https://blog.csdn.net/CYK_byte/article/details/133245090