我試圖找到方法來更新部分文件在天青宇宙數據庫但失敗。
It好像天青宇宙db現在不支持partial updates
。您可以更新整個文檔stored procedure
。
示例代碼如下以供參考:
function updateSproc(id, update) {
var collection = getContext().getCollection();
var collectionLink = collection.getSelfLink();
var response = getContext().getResponse();
tryQueryAndUpdate();
function tryQueryAndUpdate(continuation) {
var query = {query: "select * from root r where r.id = @id", parameters: [{name: "@id", value: id}]};
var requestOptions = {continuation: continuation};
var isAccepted = collection.queryDocuments(collectionLink, query, requestOptions, function (err, documents, responseOptions) {
if (err) throw err;
if (documents.length > 0) {
tryUpdate(documents[0]);
} else {
throw new Error("Document not found.");
}
});
}
function tryUpdate(document) {
var requestOptions = {etag: document._etag};
var fields, i;
fields = Object.keys(update);
for (i = 0; i < fields.length; i++) {
document[fields[i]] = update[fields[i]];
}
var isAccepted = collection.replaceDocument(document._self, document, requestOptions, function (err, updatedDocument, responseOptions) {
if (err) throw err;
response.setBody(updatedDocument);
});
}
然而,天青波斯菊DB支持MongoDB protocol
。您可以在Azure official page上確認。因此,incremental operations
支持。請參閱此link。
希望它可以幫助你。任何關注,請隨時讓我知道。
我知道documentdb不支持部分更新,我只需要在替換整個文檔之前遞增votecount值。 –