gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 03:25:08 25 4
gpt4 key购买 nike

我的一台 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com