一.创建文档
创建文档的有两种方式
PUT创建文档: 需要指定文档的Id
POST创建文档: 不需要指定文档ID,Elasticsearch 可以帮我们自动生成 ID,自动生成的 ID 是 URL-safe、 基于 Base64 编码且长度为20个字符的 GUID 字符串
PUT /website/blog/123
{
"title": "My first blog entry",
"text": "Just trying this out...",
"date": "2014/01/01"
}
POST /website/blog/
{
"title": "My second blog entry",
"text": "Still trying this out...",
"date": "2014/01/01"
}
二.获取文档
获取详细文档信息在请求的后面加上pretty : GET /website/blog/123?pretty
获取显示指定字段的信息使用_source,后面跟要显示字段 : GET /website/blog/123?_source=title,text
获取只显示文档中的字段的信息 : GET /website/blog/123/_source
获取文档下的所有的信息 : GET /website/blog/_search
使用_mget获取多个文档
GET /_mget
{
"docs" : [
{
"_index" : "website",
"_type" : "blog",
"_id" : 123
},
{
"_index" : "megacorp",
"_type" : "employee",
"_id" : 1,
"_source": [
"title","text"
]
}
]
}
在相同的索引的文档下获取多条数据
GET /website/blog/_mget { "docs" : [ { "_id" : 2 }, { "_type" : "pageviews", "_id" : 1 } ] }
使用 Id获取文档
GET /website/blog/_mget { "ids" : [ "2", "1" ] }
三.判断文档
检查文档是否存在,使用HEAD : HEAD /website/blog/123
四.更新文档
1.使用PUT更新
PUT更新是对文档中字段全部进行更新
PUT /website/blog/123
{
"title": "My first blog entry",
"text": "I am starting to get the hang of this...",
"date": "2014/01/02"
}
2.使用POST更新
POST更新需要使用_update,在更新文档是对文档的局部字段进行更新
POST /website/blog/123/_update
{
"doc" : {
"date": "2018/01/06",
"tags": ["test","search"]
}
}
3.使用脚本更新 例如:
POST /website/blog/123/_update
{
"script" : "ctx._source.views+=1"
}
五.删除文档
删除文档 : DELETE /website/blog/12345
如果文档存在,删除会返回200 , 文档不存在,执行删除时会返回404
六.批量文档操作
使用 bulk 进行文档批量操作
action
必须是以下选项之一:
create
如果文档不存在,那么就创建它。详情请见 创建新文档。
index
创建一个新文档或者替换一个现有的文档。详情请见 索引文档 和 更新整个文档。
update
部分更新一个文档。详情请见 文档的部分更新。
delete
删除一个文档。详情请见 删除文档。
metadata
应该 指定被索引、创建、更新或者删除的文档的 _index
、 _type
和 _id
。
POST /_bulk
{ "delete": { "_index": "website", "_type": "blog", "_id": "1234" }}
{ "create": { "_index": "website", "_type": "blog", "_id": "1234" }}
{ "title": "My first blog post" }
{ "index": { "_index": "website", "_type": "blog" }}
{ "title": "My second blog post" }
{ "update": { "_index": "website", "_type": "blog", "_id": "1234", "_retry_on_conflict" : 3} }
{ "doc" : {"title" : "My updated blog post"} }