sql >> Databáze >  >> NoSQL >> MongoDB

MapReduce v PyMongu

Můžete použít rámec agregace

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)

Nebo efektivněji pomocí $map a $setDifference operátory.

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 }}}
])

Což dává:

{'_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. Nelze přečíst vlastnost 'castForQuery' z undefined na castArrayFilters v Node.js

  2. Je možné neblokovat Redis pubsub?

  3. Jak nastavit Yii2 pomocí konfigurace Redis

  4. Jak importovat soubor Geojson do MongoDB