盛年不重来,一日难再晨,及时当勉励,岁月不待人。这篇文章主要讲述(转)Elasticsearch索引mapping的写入查看与修改相关的知识,希望能为你提供帮助。
mapping的写入与查看首先创建一个索引:
curl -XPOST "http://127.0.0.1:9200/productindex"
{"acknowledged":true}
现在只创建了一个索引,并没有设置mapping,查看一下索引mapping的内容:
curl -XGET "http://127.0.0.1:9200/productindex/_mapping?pretty"
{
"productindex" : {
"mappings" : { }
}
}
可以看到mapping为空,我们只创建了一个索引,并没有进行mapping配置,mapping自然为空。
下面给productindex这个索引加一个type,type name为
product
,并设置mapping:curl -XPOST "http://127.0.0.1:9200/productindex/product/_mapping?pretty" -d \'
{
"product": {
"properties": {
"title": {
"type": "string",
"store": "yes"
},
"description": {
"type": "string",
"index": "not_analyzed"
},
"price": {
"type": "double"
},
"onSale": {
"type": "boolean"
},
"type": {
"type": "integer"
},
"createDate": {
"type": "date"
}
}
}
}
\'{
"acknowledged" : true
}
上面的操作中,我们给productindex加了一个type,并写入了product的mapping信息,再次查看:
curl -XGET "http://127.0.0.1:9200/productindex/_mapping?pretty"
{
"productindex" : {
"mappings" : {
"product" : {
"properties" : {
"createDate" : {
"type" : "date",
"format" : "strict_date_optional_time||epoch_millis"
},
"description" : {
"type" : "string",
"index" : "not_analyzed"
},
"onSale" : {
"type" : "boolean"
},
"price" : {
"type" : "double"
},
"title" : {
"type" : "string",
"store" : true
},
"type" : {
"type" : "integer"
}
}
}
}
}
}
修改mapping如果想给product新增一个字段,那么需要修改mapping,尝试一下:
curl -XPOST "http://127.0.0.1:9200/productindex/product/_mapping?pretty" -d \'{
"product": {
"properties": {
"amount":{
"type":"integer"
}
}
}
}\'
{
"acknowledged" : true
}
新增成功。
如果要修改一个字段的类型呢,比如onSale字段的类型为boolean,现在想要修改为string类型,尝试一下:
curl -XPOST "http://127.0.0.1:9200/productindex/product/_mapping?pretty" -d \'{
"product": {
"properties": {
"onSale":{
"type":"string"
}
}
}
}\'
返回错误:
{
"error" : {
"root_cause" : [ {
"type" : "illegal_argument_exception",
"reason" : "mapper [onSale] of different type, current_type [boolean], merged_type [string]"
} ],
"type" : "illegal_argument_exception",
"reason" : "mapper [onSale] of different type, current_type [boolean], merged_type [string]"
},
"status" : 400
}
为什么不能修改一个字段的type?原因是一个字段的类型修改以后,那么该字段的所有数据都需要重新索引。Elasticsearch底层使用的是lucene库,字段类型修改以后索引和搜索要涉及分词方式等操作,不允许修改类型在我看来是符合lucene机制的。
这里有一篇关于修改mapping字段的博客,叙述的比较清楚:Elasticsearch 的坑爹事——记录一次mapping field修改过程,可以参考.
【(转)Elasticsearch索引mapping的写入查看与修改】转自:http://blog.csdn.net/napoay/article/details/52012249
推荐阅读
- Android 复制文本内容到系统剪贴板(自由复制)
- mybatis如何根据mapper接口生成其实现类
- 关于Android原生Email的自己的一些认识
- cs:app 第二章homework
- Android下获取FPS的几种方法
- CENTOS7 下Android 开发- Android Studio安装
- Android - 简单listview
- Apache Spark 2.2.0 中文文档 - Submitting Applications | ApacheCN
- Qt on Android 资源文件系统qrc与assets