繁体   English   中英

Couchbase与Cloudant CouchDB-在减少方面与Javascript的区别

[英]Couchbase vs Cloudant CouchDB - differences with Javascript in reduce

好的,这整个周末我一直在想办法,我终于陷入了困境。 我的reduce map func:

function(doc) {
 if(doc.primary_keys) {
    for(pi in doc.primary_keys) {
        var pk = doc.primary_keys[pi];

        for(row_i in doc.data) {
            var row = doc.data[row_i];
            if(row[pk]) {
                emit([row[pk]], doc._id);
            }
        }
    }
 }
}

我的看法减少了:

 function(keys, values) {
   var retval = {};

   for(var val_i in values) {
       var key = values[val_i];

       if(key in retval) {
           retval[key] += 1;
       } else {
           retval[key] = 1;
       }
    }

    return(retval);
 }

这是我的本地(Couchbase)CouchDB返回的内容:

key      value
["a"]    {test2: 1, test: 1}

但是这是Cloudant的回报:

key      value
["a"]        {[object Object]: 1, [object Object]: 1}

我怀疑js env有所不同,但是每个解决方法都将我引向同一个问题。 Cloudant的values [val_i]值是对象类型,我希望在其中输入字符串。 我不知道为什么。 如果有帮助的话,我现在很乐意重新降低。

为什么这些完全不同???

首先,您需要指定在减少情况下减少功能的工作方式( http://wiki.apache.org/couchdb/Introduction_to_CouchDB_views包含信息)。 在Cloudant上,总是调用rereduce(将各种分片中的数据收集到最终视图结果中)。 这就是为什么您得到看到的答复的原因。

其次,您似乎正在尝试通过primary_key获取数据计数。 通常,您要为此使用内置的_sum函数-它比自定义js代码更快,并且_sum对Cloudant中的对象起作用。

第三,未缩减的视图将自动包含doc._id,因此发出1来使_sum有效。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM