0

我使用 PouchDB 将用户数据从网站保存到 CouchDB(在 IrisCouch 上)。出现错误后,我推送了已命名的文档。我试图恢复承认存在冲突的冲突文件。

db.get('threshold0_1_3', {conflicts: true}).then(function (doc) {
  console.log(doc, doc._conflicts);
}).catch(function (err) {
  console.log(err)
});

但是doc._conflicts为 null 并且文档没有“_conflicts”属性。

所以我试图与这段代码产生冲突:

var db = new PouchDB("http://127.0.0.1:5984/test");
var data = {"_id": "testDoc", "count": 1};

db.put(data).then(function (response) {
  // handle response
}).catch(function (err) {
  console.log(err);
});

// modify document
data = {"_id": "testDoc", "count": 2};

db.put(data).then(function (response) {
  // handle response
}).catch(function (err) {
  console.log(err);
});

// Output
o {status: 409, name: "conflict", message: "Document update conflict", error: true, reason: "Document update conflict."}

// Check if the doc contains ._conflicts
db.get('testDoc', {conflicts: true}).then(function (doc) {
  console.log(doc);
  console.log(doc._conflicts);
}).catch(function (err) {
  console.log(err)
});

// Output:
Object {_id: "testDoc", _rev: "1-74620ecf527d29daaab9c2b465fbce66", count: 1}
undefined

我在这里缺少什么?

4

1 回答 1

1

409 表示put()被拒绝,因为它产生冲突。要手动创建冲突(如果您真的想要),您需要put()在两个不同的数据库中两次复制同一文档,然后复制它们。这是一个示例脚本。

var PouchDB = require('pouchdb');

var db1 = new PouchDB('foo');
var db2 = new PouchDB('bar');

db1.put({_id: 'doc'}).then(function () {
  return db2.put({_id: 'doc'});
}).then(function () {
  return db1.sync(db2);
}).then(function () {
  return db1.get('doc', {conflicts: true});
}).then(function (doc) {
  console.log(JSON.stringify(doc));
}).catch(console.log.bind(console));

这打印出来:

{"_id":"doc","_rev":"1-94c8f741dd8ab2a80ff49b1335e805fb","_conflicts":["1-2e0e51eeaf0d9d67b8293f205b8e4a0c"]}
于 2015-10-22T12:01:17.703 回答