网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
前言
写这篇东西,是因为官方文档看着太痛苦,于是乎想用大白话来聊聊 ElasticSearc (下面都简称ES)。所以下文对于 ES 一些概念的表述可能会与官方有出入,所以需要准确的表述和详细定义的,请跳转官方文档。我也尽量贴上官方的链接。
前置知识:因为下文会使用 mysql 的一些概念来描述,所以没学过的不建议看文本。
本文基于 ES 8.12
ES 基础概念
ES 是一个搜索引擎。重点是大数据搜索,如果是传统的 CRUD,请考虑关系型数据库。
下面来了解几个 ES 的基础概念
索引(index)
Index modules | Elasticsearch Guide [8.12] | Elastic
类比 mysql 的表,但又与表有很大区别
mysql:创建表需要先定义表字段,再进行数据插入。并且如果添加新字段,需要先修改表结构,再进行数据插入。
ES:索引无需预先定义字段(ES 里面叫映射),可在插入数据时动态添加字段(这叫动态映射,后面讲)
文档类型(type)
ES7 开始,文档类型只有默认的 _doc
了,我没用过旧版,所以略…
文档(document)
类比 mysql 的表的一条数据。
映射(mapping)
Mapping | Elasticsearch Guide [8.12] | Elastic
类比 mysql 的表字段,不同类型的字段,存储和查找会有区别
查看索引的映射
-- 查看映射(索引名为 my-index 的映射)
GET /my-index/_mappings
-- 查看映射的某个字段(索引名为 my-index 的字段 age 的映射)
GET /my-index/_mapping/field/age
动态映射
Dynamic field mapping | Elasticsearch Guide [8.12] | Elastic
ES 与传统关系型数据库不同,创建索引(类比 mysql 的表)时,不需要指定字段,在插入数据时,会自动创建字段和判断字段的类型,这就是动态映射。
动态映射默认的开启的,可以通过 dynamic 参数来修改。dynamic | Elasticsearch Guide [8.12] | Elastic
以下是不同 dynamic 参数对 json 数据类型的映射
JSON 数据类型 | dynamic: true | dynamic: runtime |
---|---|---|
null | No field added | No field added |
true or false | boolean | boolean |
double | float | float |
long | long | long |
object | object | No field added |
array | 取决于数组中的第一个非 null 值 | 取决于数组中的第一个非 null 值 |
日期类型的 string | date | date |
数字类型的 string | float or long | double or long |
其他类型的 string | text with a .keyword sub-field | keyword |
注意:默认的数字检测是关闭的,也就是在 没有映射 的情况下,插入 666 字符串是识别的成字符串的。如果已经配置了映射字段是 long 类型,插入 666 字符串才会被识别为数字
日期检测:
默认的日期检测格式有 yyyy/MM/dd HH:mm:ss||yyyy/MM/dd
也就是 2024/01/01 12:00:00 或者 2024/01/01 ,但是 2024-01-01 格式也行, 2024-01-01 12:00:00 不可以
自定义日期检测
PUT my-index
{
"mappings": {
"dynamic\_date\_formats": [ "yyyy/MM", "MM/dd/yyyy"]
// 或者用
![img](https://img-blog.csdnimg.cn/img_convert/fe0b669acb78005fe7540a8e580e7876.png)
![img](https://img-blog.csdnimg.cn/img_convert/deee69125e9bcf6b452fccf3cf6c19e6.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
://bbs.csdn.net/topics/618545628)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**