Cloudant/couchdb 由于 409 冲突,无法删除文档

Cloudant/couchdb document can't be deleted due to 409 conflict

我在 IBM Bluemix 中有一个 Java 应用程序 运行,它使用 Cloudant (couchdb) 数据库作为服务。我在该数据库中有一个无法删除的文档,因为 Cloudant returns 在我尝试时出现 409 冲突错误。但是,当我查询它是否有冲突时,它没有报告任何:

$ curl 'https://<user>-bluemix:<pass>@<host>-bluemix.cloudant.com/<dbname>/e4eca7af-cb27-4b1e-b738-31abcf880680?conflicts=true' 
{
"_id": "e4eca7af-cb27-4b1e-b738-31abcf880680", 
"_rev": "13887-a24ecaf2f6e628903e294b11e73d8ca8", 
...[other stuff but no _conflicts section]
}

当我尝试删除它时:

$ curl -i -X DELETE 'https://<user>-bluemix:<pass>@<host>-bluemix.cloudant.com/<dbname>/e4eca7af-cb27-4b1e-b738-31abcf880680?_rev=13887-a24ecaf2f6e628903e294b11e73d8ca8'
HTTP/1.1 409 Conflict
X-Couch-Request-ID: 02286a98ac
Server: CouchDB/1.0.2 (Erlang OTP/R14B)
Date: Wed, 15 Apr 2015 12:35:00 GMT
Content-Type: text/plain;charset=utf-8
Content-Length: 58
Cache-Control: must-revalidate
Strict-Transport-Security: max-age=31536000
X-Content-Type-Options: nosniff;

{"error":"conflict","reason":"Document update conflict."}

这是一个已被删除并重新创建多次的文档(这就是 _rev 计数如此之高的原因)。通常它工作正常,但时不时地进入这种冲突状态。我发现我可以通过 Cloudant Web 界面删除它,但似乎不能通过 REST 界面。但是一旦我删除它,它可以正常工作一段时间,然后问题又来了。

那为什么我删除的时候说有冲突,但是不告诉我'conflicts=true'参数有什么冲突呢?我也试过 '_deleted_conflicts=true' 但这也没有显示任何内容。

它是如何进入这种状态的,我该如何防止它在未来发生?

与我们的 cloudant 支持人员交谈,实际上 rev= 不是 _rev=

你需要说 ?rev=,而不是 ?_rev= 才能正确通过修订。

http://docs.couchdb.org/en/1.6.1/api/document/common.html#delete--db-docid

在 Cloudant 中删除文档时,必须提供修订标记作为 "rev" 参数。您正在传递一个“_rev”参数。您看到的错误好像您根本没有通过修订。

https://docs.cloudant.com/api.html#delete36