1.Setting 是 针对于索引库而言
可以设置索引库的分片数量 和 副本数量
url 的方式 设置和修改
"settings": {
"number_of_shards": 5,
"number_of_replicas": 1
api 前面在创建索引库的时候已经讲过了,就不重复了
2.Mappings相当于数据库中对字段的类型约束 以及 某些字段查询时指定分词器
具体解释请看官网
包含数据类型 (text,keyword,date,long,interger……………)
别的不多说了 看下我创建的mapping
"mappings": {
"user": {//映射类型
"properties": {//定义字段
"title": {
"type": "text",//字段类型
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"//查询分词
},
"name": {
"type": "text"
},
"age": {
"type": "long"
}
}
},
"blog": {
"properties": {
"title": {
"type": "text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"
},
"content": {
"type": "text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"
}
}
}
}
创建Mapping的javaApi
// 以XContentBuilder形式
XContentBuilder builder = XContentFactory.jsonBuilder()
.startObject()
.startObject("properties")
.startObject("name")
.field("type", "text")
.endObject()
.startObject("title")
.field("type", "text")
.field("analyzer", "ik_max_word")
.field("search_analyzer", "ik_max_word")
.endObject()
.endObject()
.endObject();
PutMappingResponse response = client.admin().indices().preparePutMapping()
.setIndices("dragon").setType("ccc")
.setSource(builder).get();
System.out.println(response.isAcknowledged());
//以json形式: 要注意要指定type setType
josn文件: { "properties": {
"title": {
"type": "text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"
},
"name": {
"type": "text"
},
"age": {
"type": "long"
}
}}
String json ="{ \"properties\": {\n" +
" \"title\": {\n" +
" \"type\": \"text\",\n" +
" \"analyzer\": \"ik_max_word\",\n" +
" \"search_analyzer\": \"ik_max_word\"\n" +
" },\n" +
" \"name\": {\n" +
" \"type\": \"text\"\n" +
" },\n" +
" \"age\": {\n" +
" \"type\": \"long\"\n" +
" }\n" +
" }}";
byte[] bytes = json.getBytes();
PutMappingResponse response = client.admin().indices()
.preparePutMapping("dragon").setType("aaa")
.setSource(json, XContentType.JSON).get();
System.out.println(response.isAcknowledged());
}
我创建 一个索引库这样来:
curl -XPUT 'localhost:9200/索引库名' -d '
{
"settings": {
"number_of_shards": 5,
"number_of_replicas": 1
},
"mappings": {
"user": {
"properties": {
"title": {
"type": "text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"
},
"name": {
"type": "text"
},
"age": {
"type": "long"
}
}
},
"blog": {
"properties": {
"title": {
"type": "text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"
},
"content": {
"type": "text",
"analyzer": "ik_max_word",
"search_analyzer": "ik_max_word"
}
}
}
}
}
' //别忘了这个