如何在PICHDB中实施部分更新?
-
21-12-2019 - |
题
让我们说你有以下doc:
{ title: 'take out the trash', priority: 'medium' }
.
,您有两个不同的客户端同时编辑此数据,例如,客户1想要将标题更改为清洁菜肴和客户端2想要将优先级更改为 high 。
如何使用pizhdb实现?
解决方案
更新处理程序和部分更新在CouchDB中支持,但他们需要每个更新的REST呼叫,这会击败使用PICHDB脱机和同步的目的。另一个解决方案是使用每个DOC是DELTA 方法。
function merge(obj1, obj2) {
for (var i in obj2) {
obj1[i] = obj2[i];
}
}
function all(db) {
return new Promise(function(fulfill, reject) {
var docs = {};
db.allDocs({include_docs: true}, function(err, doc) {
// sort by createdAt as cannot guarantee that order preserved by pouch/couch
doc.rows.sort(function(a, b) {
return a.doc.$createdAt > b.doc.$createdAt;
});
doc.rows.forEach(function(el, i) {
if (!el.doc.$id) { // first delta for doc?
el.doc.$id = el.doc._id;
}
if (docs[el.doc.$id]) { // exists?
merge(docs[el.doc.$id], el.doc);
} else {
docs[el.doc.$id] = el.doc;
}
if (i == doc.rows.length - 1) { // last element?
fulfill(docs);
}
});
});
});
}
.
function put(object, db) {
object.$createdAt = (new Date()).toJSON();
return new Promise(function(fulfill, reject) {
db.post(object).then(function(object) {
fulfill(object);
});
});
}
.
有关一个完整的示例,请参阅使用pouch 部分更新
不隶属于 StackOverflow