2

我在 CouchDB 中有一个数据库,我想知道是否可以直接从 python 创建视图而不是使用 GUI。我是 CouchDB 的初学者,我需要一个与 SQL 中的 SELECT DISTINCT 等效的函数和一个类似的视图

function (doc) {
  if(doc.MovieId == "1254")
    emit(doc.Rating, 1);
}

是理想。问题是我必须为更多MovieId的 s 做这个视图(取自键盘输入)。

我在问你是否可以直接从 python 创建/删除这样的视图,因为在网上我什么也没找到。如果不可能,我自己进行 Mango 查询和映射结果是个好主意吗?

- -编辑 - -

json_data = {
  "_id": "_design/titaRat",
  "_rev": "3-ceb11154b13457c55b1f98f4e9d15b03",
  "views": {
    "titRat": {
      "map": "function (doc) { var id_prefix = \"ratings :\"; if(doc._id.substr(0, id_prefix.length) === id_prefix && doc.MovieId == \"1721\") emit(doc.Rating, 1);}",
      "reduce": "_count"
    }
  },
  "language": "javascript",
  "options": {
    "partitioned": False
  }
}

db.save(json_data)


ResourceConflict: ('conflict', 'Document update conflict.')

我收到此错误,但没有具有此名称的文档

4

2 回答 2

1

我有一个功能:

def createView( dbConn, designDoc, viewName, mapFunction ):
    data = {
            "_id": f"_design/{designDoc}",
            "views": {
                viewName: {
                    "map": mapFunction
                    }
            },
            "language": "javascript",
            "options": {"partitioned": False }
            }
    logging.info( f"creating view {designDoc}/{viewName}" )
    dbConn.save( data )

调用的一个例子是:

mapFunction = '''function (doc) {
                      if( doc.type == 'word')
                      emit(doc.word, doc);
                    }'''
createView( db, "DESIGN_DOC_NAME", "VIEW_NAME", mapFunction )
于 2020-12-23T23:07:27.030 回答
0

你可以从 python 中创建一个视图,就像在 couch deb 中创建任何文档一样。

不同之处在于您需要创建一个设计文档。

您的函数的文档如下所示:

{
  "views": {
    "movie_ratings_view": {
      "map": "function(doc) { if(doc.MovieId == "1254") emit(doc.Rating, 1); }",
    }
  }
}

如您所见,地图函数保存为字符串。如果你想添加格式,你需要添加它,\n例如\t

要保存此文档,您可以将POST其保存到 POST /{db}/_design/movie_ratings_ddoc

然后,您可以通过以下方式调用您的视图GET /{db}/_design/movie_rations_ddoc/_view/movie_ratings_view

您可以为每个设计文档保存多个视图。

如果您想删除一个视图,您可以删除整个设计文档,或者只使用从对象中删除的视图更新设计文档。

有关如何使用视图的更多信息,请阅读:https ://docs.couchdb.org/en/master/api/ddoc/views.html

于 2020-05-01T00:37:54.977 回答