4

使用CouchDB,我目前有一个代表一个想法的文档,你可以评价这个想法。每个想法都是一个文件,每个评级都是一个不同的文件。我这样做是为了避免人们在评价一个想法时出现并发访问问题。

我的文件看起来像这样(我已经简化了它们):

一个想法:

{
 "_id": "idea1",
 "title": "A great idea"
}

评分:

{
 "_id": "rating1",
 "rating": 1,
 "author": "author1"
}

{
 "_id": "rating2",
 "rating": 1,
 "author": "author2"
}

我目前使用 reduce 函数返回想法 ID 和他/她的评分(评分的简单总和):

地图:

function(doc) {
  if (doc.type == "rating")
    emit(doc.idea_id, doc.rating);    
}

减少:

function(keys, values, rereduce) {
  return sum(values);
}

我的问题是:我如何将“想法”文档与代表想法评级的减少结果“加入”?

4

2 回答 2

7

地图:

function(doc) {
    switch (doc.type) {
        case "idea":   emit(doc._id,     ["idea",  doc]);         break;
        case "rating": emit(doc.idea_id, ["rating", doc.rating]); break;
    }
}

减少:

function(keys, values, rereduce) {
    var i, l, ret = {idea:null, rating:0};

    for (i = 0, l = values.length; i < l; ++i) {
        switch (values[i][0]) {
            case "idea":   ret.idea = values[i][1];    break;
            case "rating": ret.rating += values[i][1]; break;
        }
    }

    return ret;
}

另一种选择是使用视图排序规则来解决问题。

于 2009-12-31T15:36:25.470 回答
1

首先,请不要创建自己的 _id,让 CouchDB 为您创建一个 uuid。好多了,我向你保证:)

简短的回答是,除了附加查询之外,您无法获得想法文档。尽管查询非常快,因为您的投票文档中有 _id。

如果您想返回所有投票的完整文件,以获取评论或其他内容,您绝对可以这样做。只需使用 ?include_docs=true 运行视图查询

于 2009-12-23T19:13:41.273 回答