当前位置:   article > 正文

ElasticSearch - 索引库和文档相关命令操作_elasticsearch创建索引命令

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 的处理方式,就是按照 “删除旧文档,新增新文档” 的操作来修改文档的.

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号