bulk es 删除_分布式ES:批量操作 bulk 之 create、index、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中指定

bulk 之 create

新增文档数据,在metadata中指定index以及type

POST http://10.0.0.220:9200/_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"}

create创建已有id文档,在url中指定index和type

POST http://10.0.0.220:9200/shop/_doc/_bulk

{"create": {"_id": "2003"}}

{"id": "2003", "nickname": "name2003"}

{"create": {"_id": "2004"}}

{"id": "2004", "nickname": "name2004"}

{"create": {"_id": "2005"}}

{"id": "2005", "nickname": "name2005"}

bulk 之 index

已有文档id会被覆盖,不存在的id则新增

POST http://10.0.0.220:9200/shop/_doc/_bulk

{"index": {"_id": "2004"}}

{"id": "2004", "nickname": "index2004"}

{"index": {"_id": "2007"}}

{"id": "2007", "nickname": "name2007"}

{"index": {"_id": "2008"}}

{"id": "2008", "nickname": "name2008"}

bulk 之update

更新部分文档数据

POST http://10.0.0.220:9200/shop/_doc/_bulk

{"update": {"_id": "2004"}}

{"doc":{ "id": "3004"}}

{"update": {"_id": "2007"}}

{"doc":{ "nickname": "nameupdate"}}

bulk 之delete

批量删除

POST http://10.0.0.220:9200/shop/_doc/_bulk

{"delete": {"_id": "2004"}}

{"delete": {"_id": "2007"}}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值