簡體   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