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

Подреждане и таблично (уникално/броене) в Mongo

Току-що изпробвах новата рамка за агрегиране, която ще бъде налична във версия 2.2 на MongoDB (2.2.0-rc0 беше пусната), която трябва да има по-висока производителност от намаляването на картата, тъй като не разчита на Javascript.

входни данни:

{ "_id" : 1, "age" : 22.34, "gender" : "f" }
{ "_id" : 2, "age" : 23.9, "gender" : "f" }
{ "_id" : 3, "age" : 27.4, "gender" : "f" }
{ "_id" : 4, "age" : 26.9, "gender" : "m" }
{ "_id" : 5, "age" : 26, "gender" : "m" }

команда за агрегиране за пол:

db.collection.aggregate(
   {$project: {gender:1}},
   {$group: {
        _id: "$gender",
        count: {$sum: 1}
   }})

резултат:

{"result" : 
   [
     {"_id" : "m", "count" : 2},
     {"_id" : "f", "count" : 3}
   ],
   "ok" : 1
}

За да получите възрастите в кошчета:

db.collection.aggregate(
   {$project: {
        ageLowerBound: {$subtract:["$age", {$mod:["$age",2]}]}}
   },
   {$group: {
       _id:"$ageLowerBound", 
       count:{$sum:1}
   }
})

резултат:

{"result" : 
    [
       {"_id" : 26, "count" : 3},
       {"_id" : 22, "count" : 2}
    ],
    "ok" : 1
}


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Как да публикувате MongoDB данни във вложения масив с помощта на NODE.js и Express

  2. mongoDB добавя специфични данни към db Replica

  3. Допълнителните полета на Mongo dbref са невидими в mongoshell. Как да ги покажем?

  4. Как да изпълня MongoDB js скрипт с помощта на Java MongoDriver

  5. Създайте индекс за заместващ текст в MongoDB