需要说明couchdb减少功能

Ala*_*lan 9 couchdb couchdb-futon

来自http://wiki.apache.org/couchdb/Introduction_to_CouchDB_views

couchdb reduce函数定义为

function (key, values, rereduce) {
    return sum(values);
}
Run Code Online (Sandbox Code Playgroud)
  • key将是一个数组,其元素是[key,id]形式的数组
  • values将是为键中的各个元素发出的值的数组
  • 即reduce([[key1,id1],[key2,id2],[key3,id3]],[value1,value2,value3],false)

我无法理解何时/为什么键数组将包含不同的键值.如果键数组确实包含不同的键值,我将如何处理它?

例如,假设我的数据库包含表单帐户之间的移动.

{"amount":100, "CreditAccount":"account_number", "DebitAccount":"account_number"}
Run Code Online (Sandbox Code Playgroud)

我想要一个提供帐户余额的视图.

我的地图功能有:

emit( doc.CreditAccount, doc.amount )
emit( doc.DebitAccount, -doc.amount )
Run Code Online (Sandbox Code Playgroud)

我的reduce函数有:

回报总和(值);

我似乎得到了预期的结果,但是我无法将此与我的reduce函数获得不同键值的可能性相协调.

我的reduce函数是否应该首先对键值进行分组?在那种情况下我会返回什么样的结果?

Jas*_*ith 3

默认情况下,Futon 对您的结果进行“分组”,这意味着您将获得每个键的新减少 - 在您的情况下,是一个帐户。群组功能正是针对这种情况。

通过原始 HTTP API,您将获得所有帐户的一次总计减少,这可能没有用。因此,请记住在您自己的应用程序中使用 group=true 以确保您获得每个帐户的摘要。