Elasticsearch 动态映射——自动检测
ES中有一个非常重要的特性——动态映射,即索引文档前不需要创建索引、类型等信息,在索引的同时会自动完成索引、类型、映射的创建。
那么什么是映射呢?映射就是描述字段的类型、如何进行分析、如何进行索引等内容。
本篇就着重讲述下,ES中映射的自动检测特性。
更多内容参考:Elastisearch知识总结
字段自动检测
在某个字段第一次出现时,如果之前没有定义过映射,ES会自动检测它可能满足的类型,然后创建对应的映射。
JSON数据 |
ES中的数据类型 |
|
不会添加字段 |
|
boolean |
floating point number |
double |
integer |
long |
object |
object |
array |
依赖于第一个非null得值 |
string |
如果通过了date检测,则为date 如果通过了numeric检测,则为Number |
上面就是类型自动检测的结果,除了上面列出的基本类型,其他的高级的类型比如geo,ip就需要手动指定了。
日期自动检测
日期自动检测,即date_detection是默认开启的,因此只要符合默认的日期格式,就可以自动创建成date类型
日期的格式为:
[ "strict_date_optional_time","yyyy/MM/dd HH:mm:ss Z||yyyy/MM/dd Z"]
例如:
$ curl -XPUT localhost:9200/test/test/1 -d '{"create":"2015/11/11"}' {"_index":"test","_type":"test","_id":"1","_version":1,"created":true} $ curl -XGET localhost:9200/test/_mapping?pretty { "test" : { "mappings" : { "test" : { "properties" : { "create" : { "type" : "date", "format" : "yyyy/MM/dd HH:mm:ss||yyyy/MM/dd" } } } } } }
可以通过修改dynamic_date_formats
修改日期格式:
PUT my_index { "mappings":{ “my_type":{"dynamic_date_formats":["MM/dd/yyyy"]} } } PUT my_index/my_type/1{"create_date":"09/25/2015"}
数字自动检测
数字自动检测,即numeric_detection默认是关闭的。因此需要手动打开:
PUT my_index {"mappings":{"my_type":{"numeric_detection":true}}}
当执行索引操作时,如果符合float型,就会自动创建为float
long型也是一样:
分类:
Elasticsearch
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
2014-12-01 JUnit报错:java.lang.ClassNotFoundException: com.mogodb.test.test
2014-12-01 Windows下安装MongoDB
2012-12-01 记录安装oracle的那些事(一)之oracle我很大