有没有好方法来替换集合中的所有couchDB对象?

时间:2017-09-22 10:53:28

标签: javascript node.js couchdb pouchdb nosql

我的一个节点服务器有一个检查FTP文件的工作,如果发现它需要,将其转换为JSON。现在它的工作是擦除couchdb数据库,并将XML文件中找到的所有新数据替换为以前的数据。

现在,由于我不希望数据库在任何时候实际上是空的(或不存在),我不会被简单地销毁,然后用新数据集重新创建它。我的节点服务器已经从数据库复制到本地pouchdb,擦除它(软删除),然后将所有新数据放入其中,然后复制到couchdb数据库。

似乎下载应该是完全没必要的,应该有一种方法来做到这一点与硬删除。有没有办法简单地用我的节点服务器复制到它的一组新对象替换当前CouchDB数据库中的所有对象?

感谢您的帮助

1 个答案:

答案 0 :(得分:1)

CouchDB将文档修订历史记录保存在树中,因此更换文档(让我们说_ID为' x'的文档)需要您知道现有修订版本#39; s _id / _rev配对或能够更新它。

因此,如果您需要更新文档' x'你必须

 // fetch the document first
 curl -X GET http://localhost:5984/mydb/x
 { "_id": "x", "_rev": "45-123", "name": "fred"}
 // to be able to update it
 curl -X PUT -d'{ "_id": "x", "_rev": "45-123", "name": "Fred Smith"}' http://localhost:5984/mydb/x
 { "ok": "true", "_id": "x", "_rev": "46-456"}

您可以重写您的作业,为每个已更改的文档执行此GET / PUT操作。

如果您需要在导入新数据之前擦除数据,则只需创建一个新数据库,例如" mydb2017-09-22&#34 ;,将数据导入其中并告诉正在使用该数据的应用" mydb2017-09-22"作为真理的来源。然后,您可以安全地安全地删除以前的规范数据库。这样可以避免当前解决方案中的复制步骤。

当前的CouchDB不支持清除,因为它会混淆数据被复制的实现。压缩是为了删除较旧的,不需要的文档修订体,以节省空间。

我不知道你的问题的一切,我建议每个导入一个数据库查看一个数据库"解决方案因为它允许您在导入完成时简单地在数据集之间切换,并通过删除旧数据库来清理它。