PouchDB删除设备上的数据而不影响远程同步

时间:2016-09-28 17:52:44

标签: javascript couchdb pouchdb

现在我正在将我的整个设备数据库复制到我的远程数据库。

完成后,我使用过滤器从远程数据库中获取所有不超过1个月的数据,并将其带到我的设备。

过滤

{
  _id: '_design/filters',
  "filters": {
    "device": function(doc, req) { 
      if(doc.type == "document" || doc.type == "signature") { 
        if(doc.created >= req.query.date) return true;
        else return false;
      } 
      else return true;
    }
  }
}

复制

device_db.replicate.to(remote_db)
.on('complete', function () {

  device_db.replicate.from(remote_db, {

    filter: "filters/device", 
    query_params: { "date": (Math.floor(Date.now() / 1000)-2419200) }

  })
  .on('complete', function () {

    console.log("localtoRemoteSync replicate.to success");
    callback(true);

  });

});

我的问题:

我希望能够定期从我的设备中删除超过3个月的数据(我已经知道的足够数据已经同步了)

但仅仅因为我从设备中删除了它,当我将数据复制回 remote_db 时,我也不希望它被删除。

如何删除设备上的特定数据,但在复制时没有翻译该删除?

1 个答案:

答案 0 :(得分:3)

FILTERS

在这里,我们有2个过滤器:

noDeleted:此过滤器不会推送 _deleted 文档。

设备:过滤以仅获取最新数据。

{
  _id: '_design/filters',
  "filters": {
      "device": function(doc, req) {
          if (doc.type == "document" || doc.type == "signature") {
              if (doc.created >= req.query.date) return true;
              else return false;
          }
          return true;
      },
       "noDeleted": function(doc, req) {
          //Document _deleted won't pass through this filter.
          //If we delete the document locally, the delete won't be replicated to the remote DB 
          return !doc._deleted;
      }
  }
}

复制

device_db.replicate.to(remote_db, {
      filter: "filters/noDeleted"
  })
  .on('complete', function() {
      device_db.replicate.from(remote_db, {
              filter: "filters/device",
              query_params: { "date": (Math.floor(Date.now() / 1000) - 2419200) }
          })
          .on('complete', function() {
              console.log("localtoRemoteSync replicate.to success");
              callback(true);
          });
  });

工作流

  1. 您无需推送已删除的文档即可推送所有文档。
  2. 您获得了最新数据的所有更新
  3. 您删除旧文档
    • 您可以查询远程数据库以获取过旧的文档的ID并在本地删除它们。请注意,文档仍将作为 _deleted 存在。要完全删除它们,将需要压缩。
    • 您也可以在第1步之后完全销毁本地数据库并从头开始。
  4. 回调(真);