【Elasticsearch】学习笔记-p2(索引库操作&文档操作)

索引库就类似数据库表,mapping映射就类似表的结构。

我们要向es中存储数据,必须先创建“库”和“表”。

1.1 mapping映射属性


mapping是对索引库中文档的约束,常见的mapping属性包括:

  • type:字段数据类型,常见的简单类型有:

  • 字符串:text(可分词的文本)、keyword(精确值,例如:品牌、国家、ip地址)

  • 数值:long、integer、short、byte、double、float、

  • 布尔:boolean

  • 日期:date

  • 对象:object

  • index:是否创建索引,默认为true

  • analyzer:使用哪种分词器

  • properties:该字段的子字段

例如下面的json文档:

{

“age”: 21,

“weight”: 52.1,

“isMarried”: false,

“info”: “黑马程序员Java讲师”,

“email”: “zy@itcast.cn”,

“score”: [99.1, 99.5, 98.9],

“name”: {

“firstName”: “云”,

“lastName”: “赵”

}

}

对应的每个字段映射(mapping):

  • age:类型为 integer;参与搜索,因此需要index为true;无需分词器

  • weight:类型为float;参与搜索,因此需要index为true;无需分词器

  • isMarried:类型为boolean;参与搜索,因此需要index为true;无需分词器

  • info:类型为字符串,需要分词,因此是text;参与搜索,因此需要index为true;分词器可以用ik_smart

  • email:类型为字符串,但是不需要分词,因此是keyword;不参与搜索,因此需要index为false;无需分词器

  • score:虽然是数组,但是我们只看元素的类型,类型为float;参与搜索,因此需要index为true;无需分词器

  • name:类型为object,需要定义多个子属性

  • name.firstName;类型为字符串,但是不需要分词,因此是keyword;参与搜索,因此需要index为true;无需分词器

  • name.lastName;类型为字符串,但是不需要分词,因此是keyword;参与搜索,因此需要index为true;无需分词器

1.2 创建索引库和映射


基本语法:

  • 请求方式:PUT

  • 请求路径:/索引库名,可以自定义

  • 请求参数:mapping映射

格式:

PUT /索引库名称

{

“mappings”: {

“properties”: {

“字段名”:{

“type”: “text”,

“analyzer”: “ik_smart”

},

“字段名2”:{

“type”: “keyword”,

“index”: “false”

},

“字段名3”:{

“properties”: {

“子字段”: {

“type”: “keyword”

}

}

},

// …略

}

}

}

示例:

PUT /heima

{

“mappings”: {

“properties”: {

“info”:{

“type”: “text”,

“analyzer”: “ik_smart”

},

“email”:{

“type”: “keyword”,

“index”: “falsae”

},

“name”:{

“properties”: {

“firstName”: {

“type”: “keyword”

}

}

},

// … 略

}

}

}

1.3 查询索引库


基本语法:

  • 请求方式:GET

  • 请求路径:/索引库名

  • 请求参数:无

格式:

GET /索引库名

示例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Cx2gcfUK-1637144046842)(C:\Users\30287\Desktop\Java学习视频\day05-Elasticsearch01\讲义\assets\image-20210720211019329.png)]

1.4 修改索引库


倒排索引结构虽然不复杂,但是一旦数据结构改变(比如改变了分词器),就需要重新创建倒排索引,这简直是灾难。因此索引库一旦创建,无法修改mapping

虽然无法修改mapping中已有的字段,但是却允许添加新的字段到mapping中,因为不会对倒排索引产生影响。

语法说明

PUT /索引库名/_mapping

{

“properties”: {

“新字段名”:{

“type”: “integer”

}

}

}

示例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UY55fnQP-1637144046848)(C:\Users\30287\Desktop\Java学习视频\day05-Elasticsearch01\讲义\assets\image-20210720212357390.png)]

1.5 删除索引库


语法:

  • 请求方式:DELETE

  • 请求路径:/索引库名

  • 请求参数:无

格式:

DELETE /索引库名

在kibana中测试:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-azqaRwcd-1637144046851)(C:\Users\30287\Desktop\Java学习视频\day05-Elasticsearch01\讲义\assets\image-20210720212123420.png)]

1.6 总结


索引库操作有哪些?

  • 创建索引库:PUT /索引库名

  • 查询索引库:GET /索引库名

  • 删除索引库:DELETE /索引库名

  • 添加字段:PUT /索引库名/_mapping

2.文档操作

=====================================================================

2.1 新增文档


语法:

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

{

“字段1”: “值1”,

“字段2”: “值2”,

“字段3”: {

“子属性1”: “值3”,

“子属性2”: “值4”

},

// …

}

示例:

POST /heima/_doc/1

{

“info”: “黑马程序员Java讲师”,

“email”: “zy@itcast.cn”,

“name”: {

“firstName”: “云”,

“lastName”: “赵”

}

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

阿里伤透我心,疯狂复习刷题,终于喜提offer 哈哈~好啦,不闲扯了

image

1、JAVA面试核心知识整理(PDF):包含JVMJAVA集合JAVA多线程并发,JAVA基础,Spring原理微服务,Netty与RPC,网络,日志,ZookeeperKafkaRabbitMQ,Hbase,MongoDB,Cassandra,设计模式负载均衡数据库一致性哈希JAVA算法数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算共30个章节。

image

2、Redis学习笔记及学习思维脑图

image

3、数据面试必备20题+数据库性能优化的21个最佳实践

image
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
微服务**,Netty与RPC,网络,日志,ZookeeperKafkaRabbitMQ,Hbase,MongoDB,Cassandra,设计模式负载均衡数据库一致性哈希JAVA算法数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算共30个章节。

[外链图片转存中…(img-gpS7Ve0c-1713523487075)]

2、Redis学习笔记及学习思维脑图

[外链图片转存中…(img-0bkMqL5W-1713523487076)]

3、数据面试必备20题+数据库性能优化的21个最佳实践

[外链图片转存中…(img-yCMjkCUa-1713523487077)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值