sql >> Database teknologi >  >> NoSQL >> MongoDB

MapReduce i PyMongo

Du kan bruge aggregationsramme

import pymongo
conn = pymongo.MongoClient()
db = conn.test
col =  db.collection

for doc in col.aggregate([{'$unwind': '$impressions'}, 
    {'$match': {'impressions.service': 'furniture'}}, 
    {'$group': {'_id': '$impressions.id', 'impressions_count': {'$sum': 1}}}, 
    ]):
    print(doc)

Eller mere effektivt ved at bruge $map og $setDifference operatører.

col.aggregate([
    { "$project": { "impressions": {"$setDifference": [{ "$map": { "input": "$impressions", "as": "imp", "in": { "$cond": { "if": { "$eq": [ "$$imp.service", "furniture" ] }, "then": "$$imp.id", "else": 0 }}}}, [0]]}}}, 
    { "$unwind": "$impressions" }, 
    { "$group": { "_id": "$impressions", "impressions_count": { "$sum": 1 }}}
])

Hvilket giver:

{'_id': 122.0, 'impressions_count': 1}
{'_id': 124.0, 'impressions_count': 1}
{'_id': 127.0, 'impressions_count': 1}
{'_id': 123.0, 'impressions_count': 2}


  1. Flaske efter eksempel – Implementering af en Redis-opgavekø

  2. Sådan gør du:Brug Apache HBase REST-grænsefladen, del 3

  3. Hvordan kan jeg løse Kunne ikke opsætte sockets under opstart, når jeg kører mongodb server?

  4. Sortering efter virtuelt felt i mongoDB (mongoose)