sql >> Databasteknik >  >> NoSQL >> MongoDB

MapReduce i PyMongo

Du kan använda aggregationsramverket

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 mer effektivt med $map och $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 }}}
])

Vilket ger:

{'_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. Nod MongoDb { err:'anslutning till [127.0.0.1:27017] tog timeout' }

  2. MongoDB:Får inte korrekt resultat med operatorn $geoWithin

  3. Spring boot försöker ansluta till mongo när man lägger till mongo-java-driver maven-beroende

  4. Importera CSV-data som en array i MongoDB med mongoimport