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

标签 javascript node.js couchdb pouchdb nosql

我的一台 Node 服务器负责检查 FTP 中的 XML 文件,如果找到,则将其转换为 JSON。现在它的工作是删除 couchdb 数据库,并用 XML 文件中找到的所有新数据替换以前的数据。

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

看来下载应该完全没有必要,应该有一种方法可以通过硬删除来做到这一点。有没有什么方法可以简单地将当前 CouchDB 数据库中的所有对象替换为我的 Node 服务器将复制到的一组新对象?

感谢您的帮助

最佳答案

CouchDB 将文档修订历史记录保存在树中,因此用新版本替换文档(假设 _id 为“x”的文档)需要您知道现有修订版本的 _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”,将数据导入其中,并告诉使用该数据的应用程序使用“mydb2017-09-22”作为事实来源。然后,您可以安全地删除以前的规范数据库。这避免了当前解决方案中的复制步骤。

当前的 CouchDB 不支持清除,因为它会扰乱数据复制的实现。压缩用于删除旧的、不需要的文档修订版以节省空间。

不知道有关您的问题的所有信息,我建议您查看“每次导入一个数据库”解决方案,因为它允许您在导入完成后简单地在数据集之间切换,并通过删除旧数据库自行清理。

关于javascript - 有没有好的方法来替换集合中的所有 couchDB 对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46363036/

相关文章:

javascript - 页面中的几个粘性标题

javascript - 存储事件未触发

node.js - TDD 测试第一个 Node Js Express Rest Api - 单元测试中间件/ Controller /路由

project-management - 将Couch-DB提升为管理层

javascript - 在 couchdb 文档中使用 javascript 和 html 向现有文档添加字段的最简单方法?

javascript - 单击弹出窗口外的选择框关闭弹出窗口

javascript - 将 css 添加到具有现有 css 的元素

node.js - 将 req.body 中的空字符串 ''“替换为 null/undefined

node.js - 在 Node 中解析ByteBuffer?

couchdb - 选择在 CouchDB 中没有某些键的文档