更新从 MyCouch Extension 调用的函数

Update functions called from MyCouch Extension

我正在尝试从 MyCouch 调用更新功能。 Mycouch 的文档仅报告了 _design 文档上使用 Post 方法的过时示例。 但是如何使用 Update 函数

{
  "_id": "_design/artists",
  "language": "javascript",
  "views": {
    "albums": {
        "map": "function(doc) {  if(doc.$doctype !== 'artist') return;  emit(doc.name, doc.albums);}" 
    }
  }
};

client.Documents.Post(designDocumentAsJson);

如何在推送新文档的_design couchDB 上执行更新功能?

couchDB 文档讲述了这个调用

PUT /{db}/_design/{ddoc}/_update/{func}/{docid}

PUT /{db}/_design/{ddoc}/_update/{func}/{docid}

Executes update function on server side for the specified document.
Parameters: 

    db – Database name
    ddoc – Design document name
    func – Update function name
    docid – Document ID

您可以将如下设计文档插入数据库:https://docs.couchdb.org/en/stable/api/ddoc/render.html#db-design-design-doc-update-update-name

{
  "_id": "_design/albums",
  "language": "javascript",
  "updates": {
    "addAlbum": "function(doc, req) {\n    if (!doc){\n      return [null, {'code': 400,\n                     'json': {'error': 'missed',\n                              'reason': 'no document to update'}}]\n    } else {\n        var body = JSON.parse(req.body);\n        doc.albums.push(body.album);\n        return [doc, {'json': {'status': 'ok'}}];\n    }\n}\n"
  }
}

函数(没有字符串化):

function(doc, req) {
    if (!doc){
      return [null, {'code': 400,
                     'json': {'error': 'missed',
                              'reason': 'no document to update'}}]
    } else {
        var body = JSON.parse(req.body);
        doc.albums.push(body.album);
        return [doc, {'json': {'status': 'ok'}}];
    }
}

示例文档:

{
  "_id": "albumsId1",
  "albums": [
    1
  ]
}

Api

之后

要求:

POST http://localhost:5984/test/_design/albums/_update/addAlbum/albumsId1
Content-Type:application/json
Accept:application/json

{"album":2}

响应:

{
    "status": "ok"
}

更新后的文档

{
  "_id": "albumsId1",
  "_rev": "19-7edb16db3bae388685f554138d562bd0",
  "albums": [
    1,
    2
  ]
}