PouchDB:没有冲突

时间:2015-10-22 09:50:09

标签: couchdb pouchdb iriscouch

我使用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为空,文档没有" _冲突"属性。

所以我试图用这段代码创建冲突:

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

我在这里缺少什么?

1 个答案:

答案 0 :(得分: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"]}