elasticsearch之Document APIs【Delete API】

本文介绍了Elasticsearch中删除文档的方法,包括基于ID删除JSON文档、版本控制、路由设置等高级功能。还讨论了自动索引创建、分布式删除操作及刷新机制等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境

虚拟机:centos7
操作系统:win7
elasticsearch:5.5

Delete API

delete api 允许从基于id的指定的数据库中删除json类型的文档。
下面的例子是从数据库twitter中的表名为tweet中删除id为1的文档:

DELETE /twitter/tweet/1

结果为:

{
    "_shards" : {
        "total" : 2,
        "failed" : 0,
        "successful" : 2
    },
    "found" : true,
    "_index" : "twitter",
    "_type" : "tweet",
    "_id" : "1",
    "_version" : 2,
    "result": "deleted"
}

Versioning(版本控制)

索引中每个文档都是被版本控制的。当删除文档时,可以指定version来确保我们正在尝试删除的相关文档实际上确实是删除的,同时没有发生更改。在文档上执行的每个写操作,包括删除,都会引起版本号增加。

Routing(路由)

当索引(数据库)使用了routing来控制路由时,为了删除文档,应该提供路由的值,例如:

DELETE /twitter/tweet/1?routing=kimchy

上面是删除表tweetid1的文档。注意,发一个没有正确路由的删除请求,会造成文档不被删除。

_routing映射为required时,并且没有指定路由的值,delete api将会抛出一个RoutingMissingException异常,并且会拒绝请求。

Parent

设置parent参数,与设置路由参数基本相同。

注意:删除父文档不会立即其子项。给一个父id来删除所有子文档的一个方法是使用Delete By Query API 来执行带自动生成(和倒排索引)字段_parent的索引(即数据库),它的格式是parent_type#parent_id

当删除子文档时其父id必须指定,否则删除请求将会被拒绝,并且会抛出RoutingMissingException异常。

Automatic index creation

如果之前没有创建索引(即:数据库)的话,删除操作将会自动创建一个索引(即数据库),并且也会自动创建一个指定的动态类型映射(如果之前没有创建的话)。

分布式

删除操作会得到一个被哈希的分片id。接着会被重定向到该id组中的主分片中,并且会被复制(如果需要)到该id组中的副本分片中。

Wait For Active Shards

当进行删除请求时,你可以设置wait_for_active_shards,参数来要求在开始处理删除请求之前,需要活动的副本分片的最小数量。有关详细信息和使用示例,可以参考这里

Refresh

用于控制通过本次请求发生的改变对于搜索是可见的。参考?refresh

Timeout

分配执行删除操作的主分片可能在执行删除操作时。可能的原因有主分片正在从存储中恢复或者正在进行迁移。默认情况下,删除操作在失败或者响应错误之前,等待主分片(变为可可用)最多一分钟。timeout参数可以用来明确指定等待多久时间。例如下面例子等待5分钟。

DELETE /twitter/tweet/1?timeout=5m

参考地址:
https://www.elastic.co/guide/en/elasticsearch/reference/current/docs-delete.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山鬼谣me

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值