抱歉,我是ElasticSearch的新手。
http://www.elasticsearch.org/guide/reference/api/admin-indices-put-mapping.html
本文档说你可以“在twitter索引中创建一个名为tweet的映射”
$ curl -XPUT 'http://localhost:9200/twitter/tweet/_mapping' -d '
{
"tweet" : {
"properties" : {
"message" : {"type" : "string", "store" : "yes"}
}
}
}
'
有人在ES IRC频道告诉我,/ twitter / tweet twitter = index,tweet = type
但是,如果我执行以下操作会发生什么?
$ curl -XPUT 'http://localhost:9200/twitter/XXX/_mapping' -d '
{
"YYY" : {
"properties" : {
"message" : {"type" : "string", "store" : "yes"}
}
}
}
'
如果我已在网址中提供了类型名称,为什么还要在内容中提供类型名称? 如果我在内容中提供类型名称,为什么我不能只调用一些URL:
$ curl -XPUT 'http://localhost:9200/twitter/_mapping' -d '
在阅读文档时,对我来说它“在twitter索引中创建了一个名为tweet的映射”,这意味着XXX是映射名称,YYY是类型名称。
因此,如果存在映射名称,则索引
通常可以有许多“映射”那么,最后,XXX和YYY是/应该是一样的?
这不是我从文档中理解的,但我认为是: - 一个索引可以有类型 - 类型有映射 因此,我们不像文档中那样创建映射,但是我们创建了一个具有映射的类型,或者我们更新了类型的映射没有?
在我不想使用任何类型的索引上(索引的所有文档都是相同类型的数据),但我想为该索引创建一个映射,我应该通过只创建一个来处理它键入其映射,并始终使用该类型(例如在CouchDB河中)?
由于
答案 0 :(得分:11)
在当前版本的elasticsearch搜索(0.19.4)" YYY"被忽略,映射被分配给" XXX"类型。
实际上,您可以将创建映射视为创建类型。在内部,类型以映射表示,文档仅反映此行为。如果所有记录都具有相同的类型,则应将索引视为仅包含一种类型的索引。类型用于"命名空间"不同类型的记录,因此它是强制性的。 id本身并不唯一地标识记录。要识别elasticsearch中的记录,您需要具有索引,类型和ID。这就是为什么type是get操作所需的参数,例如。对于其他操作,如果未指定type,elasticsearch将假定您要使用所有类型的记录执行操作。
注意,也可以通过添加新类型的记录随时动态创建类型。因此,只有一种类型的索引是一个没有第二种 的索引。