文章目錄
基本文法
批量操作的類型
實操
create
update
delete
複合操作
參考資源
基本文法
bulk操作和以往的普通請求格式有差別。不要格式化json,不然就不在同一行了,這個需要注意。
{ action: { metadata }}\n
{ request body }\n
{ action: { metadata }}\n
{ request body }\n
...
{ action: { metadata }}代表批量操作的類型,可以是新增、删除或修改
\n是每行結尾必須填寫的一個規範,每一行包括最後一行都要寫,用于es的解析
{ request body }是請求body,增加和修改操作需要,删除操作則不需要
批量操作的類型
action 必須是以下選項之一:
create:如果文檔不存在,那麼就建立它。存在會報錯。發生異常報錯不會影響其他操作。
index:建立一個新文檔或者替換一個現有的文檔。
update:部分更新一個文檔。
delete:删除一個文檔。
metadata 中需要指定要操作的文檔的_index 、 _type 和 _id,_index 、 _type也可以在url中指定
實操
create
create新增文檔資料,在metadata中指定index以及type POST /_bulk
{"create": {"_index": "shop2", "_type": "_doc", "_id": "2001"}}
{"id": "2001", "nickname": "name2001"}
{"create": {"_index": "shop2", "_type": "_doc", "_id": "2002"}}
{"id": "2002", "nickname": "name2002"}
{"create": {"_index": "shop2", "_type": "_doc", "_id": "2003"}}
{"id": "2003", "nickname": "name2003"}
1234567
create建立已有id文檔,在url中指定index和type POST /shop/_doc/_bulk
{"create": {"_id": "2003"}}
{"id": "2003", "nickname": "name2003"}
{"create": {"_id": "2004"}}
{"id": "2004", "nickname": "name2004"}
{"create": {"_id": "2005"}}
{"id": "2005", "nickname": "name2005"}
1234567
index建立,已有文檔id會被覆寫,不存在的id則新增 POST /shop/_doc/_bulk
{"index": {"_id": "2004"}}
{"id": "2004", "nickname": "index2004"}
{"index": {"_id": "2007"}}
{"id": "2007", "nickname": "name2007"}
{"index": {"_id": "2008"}}
{"id": "2008", "nickname": "name2008"}
12345678
update
update跟新部分文檔資料 POST /shop/_doc/_bulk
{"update": {"_id": "2004"}}
{"doc":{ "id": "3004"}}
{"update": {"_id": "2007"}}
{"doc":{ "nickname": "nameupdate"}}
delete
delete批量删除 POST /shop/_doc/_bulk
{"delete": {"_id": "2004"}}
{"delete": {"_id": "2007"}}
複合操作
綜合批量各種操作 POST /shop/_doc/_bulk
{"create": {"_id": "8001"}}
{"id": "8001", "nickname": "name8001"}
{"update": {"_id": "2001"}}
{"doc":{ "id": "20010"}}
{"delete": {"_id": "2003"}}
{"delete": {"_id": "2005"}}
參考資源
官文:https://www.elastic.co/guide/cn/elasticsearch/guide/current/bulk.html