关于java:删除CouchDB中过期的文档

Delete expired documents in CouchDB

我正在使用couchDB存储一些数据,我在删除n天之前插入的文档时遇到问题。

所以,我想通过视图加载我想要删除的文件,并立即对所有这些文件执行DELETE请求;但失败了。

样本文件:

1
2
3
4
5
{
"date":"20160912",
"_id":"1xxxxx",
"name":"namal"
}

查看功能:

1
2
3
4
5
function (doc) {
       if(doc.date){
          emit(doc.date,doc);
       }
    }

加载文件的网址:

HTTP://本地主机:5984 / DBX / _design / viewx / _view /日期键=%2220160910%22?

删除请求 :

1
curl -X DELETE http://localhost:5984/dbx/_design/viewx/_view/date?key=%2220160910%22

我知道我可以使用_id和_rev在每个文档中执行此操作,如下所示。

1
curl -X DELETE http://localhost:5984/dbx/1xxxxx?rev="1-1111x1111111x222222x333333"

但在这种情况下,我需要逐个删除生成的文档。我想要的是,一次删除文档列表(bluk docs)(正如我所提到的,实际的requremnet是删除在n天之前插入的文档)。

此外,我知道更好的方法是通过使用CouchBase或MongoDb设置到期时间来清除过期数据。但我正在寻找CouchDB实现中的解决方案。

注意:在这种情况下,我想让它们真的删除。不是看不见的。

  • 语言:Java 1.7
  • 操作系统:Ubuntu 14.04 64位
  • CouchDB版本:1.6.1

您可以使用CouchDB的批量文档API来更新文档(将_deleted字段设置为true的更新与删除一样好)。

更多信息:http://wiki.apache.org/couchdb/HTTP_Bulk_Document_API#Modify_Multiple_Documents_With_a_Single_Request

对于更永久的东西,您可以使用CouchDB的_purge命令。 细节在这里

请注意,不会复制此操作。 因此,如果您有复制设置,则必须在每个数据库上执行此操作。