これがあなたがする必要があることです。
マップ機能
function(doc)
{
if (doc.category)
{
emit(['category', doc.category], doc.modified);
}
}
次に、それらをグループ化するリスト関数が必要です.reduceを悪用してこれを実行したくなるかもしれませんが、大量のデータセットで十分に速く減少しないため、おそらくエラーがスローされます.
function(head, req)
{
% this sort function assumes that modifed is a number
% and it sorts in descending order
function sortCategory(a,b) { b.value - a.value; }
var categories = {};
var category;
var id;
var row;
while (row = getRow())
{
if (!categories[row.key[0]])
{
categories[row.key[0]] = [];
}
categories[row.key[0]].push(row);
}
for (var cat in categories)
{
categories[cat].sort(sortCategory);
categories[cat] = categories[cat].slice(0,10);
}
send(toJSON(categories));
}
今すぐすべてのカテゴリのトップ 10 を取得できます
http://localhost:5984/database/_design/doc/_list/top_ten/by_categories
そしてドキュメントを入手してください
http://localhost:5984/database/_design/doc/_list/top_ten/by_categories?include_docs=true
これで、複数の範囲の POST でこれをクエリし、カテゴリを制限できます
curl -X POST http://localhost:5984/database/_design/doc/_list/top_ten/by_categories -d '{"keys":[["category1"],["category2",["category3"]]}'
をハードコーディングして、変数10
を介して数値を渡すこともできません。req
これは、ビュー/リストのトリックです。