MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

MongoDB група по функционалности

MongoDB групиране по е много ограничен в повечето случаи, например

- the result set must be lesser than 10000 keys.
- it will not work in sharded environments

Така че е по-добре да използвате map reduction. така че заявката ще бъде така

map =function() { emit({a:true,b:true},{count:1}); }

reduce = function(k, values) {
    var result = {count: 0};
    values.forEach(function(value) {
        result.count += value.count;
    });
    return result;
}

и след това

db.list.mapReduce(map,reduce,{out: { inline : 1}})

Това е непроверена версия. уведомете ме дали работи

РЕДАКТИРАНЕ:

По-ранната функция на картата беше дефектна. Ето защо не получавате резултатите. трябваше да бъде

map = function () {
    emit({a:this.a, b:this.b}, {count:1});
}

Данни от теста:

> db.multi_group.insert({a:1,b:2})
> db.multi_group.insert({a:2,b:2})
> db.multi_group.insert({a:3,b:2})
> db.multi_group.insert({a:1,b:2})
> db.multi_group.insert({a:3,b:2})
> db.multi_group.insert({a:7,b:2})


> db.multi_group.mapReduce(map,reduce,{out: { inline : 1}})
{
    "results" : [
        {
            "_id" : {
                "a" : 1,
                "b" : 2
            },
            "value" : {
                "count" : 2
            }
        },
        {
            "_id" : {
                "a" : 2,
                "b" : 2
            },
            "value" : {
                "count" : 1
            }
        },
        {
            "_id" : {
                "a" : 3,
                "b" : 2
            },
            "value" : {
                "count" : 2
            }
        },
        {
            "_id" : {
                "a" : 7,
                "b" : 2
            },
            "value" : {
                "count" : 1
            }
        }
    ],
    "timeMillis" : 1,
    "counts" : {
        "input" : 6,
        "emit" : 6,
        "reduce" : 2,
        "output" : 4
    },
    "ok" : 1,
}

РЕДАКТИРАНЕ 2:

Пълно решение, включително прилагане с брой>=2

map = function () {
    emit({a:this.a, b:this.b}, {count:1,_id:this._id});
}

reduce = function(k, values) {
    var result = {count: 0,_id:[]};
    values.forEach(function(value) {
        result.count += value.count;
        result._id.push(value._id);
    });
    return result;
}

>db.multi_group.mapReduce(map,reduce,{out: { replace : "multi_result"}})

> db.multi_result.find({'value.count' : {$gte : 2}})
{ "_id" : { "a" : 1, "b" : 2 }, "value" : { "_id" : [   ObjectId("4f0adf2884025491024f994c"),   ObjectId("4f0adf3284025491024f994f") ], "count" : 2 } }
{ "_id" : { "a" : 3, "b" : 2 }, "value" : { "_id" : [   ObjectId("4f0adf3084025491024f994e"),   ObjectId("4f0adf3584025491024f9950") ], "count" : 2 } }


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Mongodb, $sum с условие

  2. Сортиране на вложен масив от обекти

  3. Съхранявайте Json низ като MongoDB масив в C#

  4. Конфигурирайте GridFS Chunksize в MongoDB

  5. Добавете поле, което не е в схемата с мангуста