0

我有一个视图,但是从视图的结果中确实有重复的文档,如下所示,我怎样才能获得重复的结果并获得唯一的?先感谢您

{
"total_rows": 9,
"offset": 0,
"rows": [

        {
            "id": "xxxx",
            "key": "12345",
            "value": {
            "_id": "abc123",
            "_rev": "4-8db4da81d1e20afcea0a328fb16e7ec8",
                "field1": "abc",
                "field2": "dfr"
            },

            {
                "id": "xxxx",
                "key": "12345",
                "value": {
                    "_id": "abc123",
                    "_rev": "4-8db4da81d1e20afcea0a328fb16e7ec8",
                    "field1": "abc",
                    "field2": "dfr"
                },
            ]
        }

景色是这样的

function(doc) {
if(doc){
    for (var i in doc.item){
            emit(doc.item[i].key,doc);
        }
    }  
}

由 ...._view/duplicate?key="12345" 调用的视图

执行以下 reduce 时,我总是遇到此错误:" error":"reduce_overflow_error","re​​ason":"Reduce 输出必须更快地收缩:

function (keys, values, rereduce) {
var uniqueKey = [];
var newValues = [];
for (var i=0; i<values.length; i++) {
    if (uniqueKey.indexOf(values[i]._id)==-1) {
        uniqueKey.push(values[i]._id);
        newValues.push(values[i]);
    }
}
return newValues;

}

4

1 回答 1

0

问题是您的地图功能:

function(doc) {
if(doc){
    for (var i in doc.item){
            emit(doc.item[i].key,doc);
        }
    }  
}

通过这样做,您会多次发出相同的文档,因此在您的视图结果中有重复的文档应该不足为奇。如果您想返回文档的所有项目而没有任何重复,您可以执行以下简单操作:

function(doc) {
  if(doc.item) {
    emit(doc.item, null)
  }     
} 

另请注意,我做emit(doc.item, null)和不做emit(doc.item, doc)。发出文档是一种不好的做法,您应该使用 option 查询视图include_docs=true。否则,您的视图索引将与您的数据库具有相同的大小。

于 2016-05-27T23:14:48.920 回答