dynamic:true 动态映射
这时默认的mapping参数,当我们往index添加一条数据时,es会自动为我们完善mapping
例如我们创建一个index:
PUT my_index
{
"mappings": {
"type": {
"properties": {
"name": {
"type": "keyword"
},
"age": {
"type": "keyword"
}
}
}
}
}
往my_index
中添加一条数据:
POST my_index/type
{
"name": "vincent",
"age": "20",
"gender": "man"
}
查看mapping:
当Elasticsearch遇到之前没有遇到的字段,会默认动态创建这个字段的类型为text
。
查询时可以查询到这条数据:
dynamic:false 静态映射
我们创建一个index:
PUT my_index2
{
"mappings": {
"type": {
"dynamic":"false",
"properties": {
"name": {
"type": "keyword"
},
"age": {
"type": "keyword"
}
}
}
}
}
设置"dynamic":"false"
我们添加一条数据:
POST my_index2/type
{
"name": "vincent",
"age": "20",
"gender": "man"
}
然后查看mapping:
可以看到mapping
结构并没有随着数据字段的增加而动态修改。
查询数据:
根据新增的字段gender
并没有查询到数据,
根据name
字段查询:
发现可以查询出结果,说明elasticsearch并没有为新增的gender
建立映射关系。所以查询不到。
总结:当elasticsearch发现到有新增字段时,因为dynamic:false
的关系,会忽略该字段,但是仍会存储该字段。
dynamic:strict 严格模式
我们创建一个index:
PUT my_index3
{
"mappings": {
"type": {
"dynamic":"false",
"properties": {
"name": {
"type": "keyword"
},
"age": {
"type": "keyword"
}
}
}
}
}
当我们插入数据时:
POST my_index3/type
{
"name": "vincent",
"age": "20",
"gender": "man"
}
会报错:
错误提示,严格动态映射异常!说人话就是,当dynamic:strict的时候,elasticsearch如果遇到新字段,会抛出异常。
总结
动态映射(dynamic:true):动态添加新的字段(或缺省)。
静态映射(dynamic:false):忽略新的字段。在原有的映射基础上,当有新的字段时,不会主动的添加新的映射关系,只作为查询结果出现在查询中。
严格模式(dynamic: strict):如果遇到新的字段,就抛出异常。