Elasticsearch 支持 JSON 格式的操作数据,它就是 DSL (Domain Specific Language),通过将查询的 DSL 看待成 AST (Abstract Syntax Tree),其中包括叶子查询子句(单一逻辑)及复合查询子句(组合逻辑)。
以下操作都在 Kibana Dev Tools 中进行实践。
索引(Index)
创建索引
# 创建索引
PUT materiel
{
"settings" : { "number_of_shards" : 3, "number_of_replicas": 1
},
"mappings" : { "properties" : { "materiel" : { "type" : "text" }, "description" : { "type" : "text" } }
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
查看索引
# 获取索引信息
GET materiel
- 1
- 2
更新索引
# 修改索引 Setting 中的 副本数量为 2
PUT materiel
{
"settings" : { "number_of_replicas": 2
}
}
##### 删除索引
```json
# 删除索引
DELETE materiel
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
文档(Document)
创建文档
# 创建索引并手动指定ID,不指定时为随机生成文档ID
POST materiel/_doc/1
{
"materiel" : "10010001",
"description" : "橙汁"
}
- 1
- 2
- 3
- 4
- 5
- 6
# 创建索引并手动指定ID,不指定ID时会报错
PUT materiel/_doc/2
{
"materiel" : "10010002",
"description" : "葡萄汁"
}
- 1
- 2
- 3
- 4
- 5
- 6
查看文档
# 指定ID获取数据
materiel/_doc/1
- 1
- 2
# 获取全部索引中的文档数据
GET _search
{ "query": { "match_all": {}
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
# 获取索引全部数据
GET materiel/_search
{
"query": { "match_all": {}
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
# 同时 POST 方法也适用用于获取全部数据
POST materiel/_search
{
"query": { "match_all": {}
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
更新文档
# POST 已存在的 ID 则为更新数据,否则为创建文档
POST materiel/_doc/1
{
"materiel" : "10010001",
"description" : "西瓜汁"
}
- 1
- 2
- 3
- 4
- 5
- 6
# PUT 已存在的 ID 则为更新数据,否则为提示失败
PUT materiel/_doc/2
{
"materiel" : "10010002",
"description" : "青瓜汁"
}
- 1
- 2
- 3
- 4
- 5
- 6
删除文档
# 根据 ID 删除对应的文档
DELETE materiel/_doc/1
- 1
- 2
文章来源: blog.csdn.net,作者:叶康铭,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/m0_38030719/article/details/109103671