MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

Mongodb-Aggregationsframework für Grails 1.3.7

Fügen Sie dies in Ihre BuildConfig.groovy ein

Abhängigkeiten {

    compile "org.mongodb:mongo-java-driver:2.10.1"
    runtime "com.gmongo:gmongo:1.1"
}

Und dann im Plugin-Bereich

Plugins {

    compile (":mongodb:1.1.0.GA"){
        excludes 'mongo-java-driver', 'gmongo'
    }
}

Dadurch wird Ihr mongodb-Plug-in aktualisiert, um die neuesten Java-Treiber und gmongo zu verwenden.

Verwenden Sie dann das Aggregationsframework. Beispiel

    DBObject match = new BasicDBObject('$match', new BasicDBObject("adPostId", 50) );

    // build the $projection operation
    DBObject fields = new BasicDBObject("adPostId", 1);
    fields.put("shopperId", 1);
    fields.put("_id", 0);
    DBObject project = new BasicDBObject('$project', fields );

    // Now the $group operation
    DBObject groupFields = new BasicDBObject( "_id", '$karmaType');
    groupFields.put("average", new BasicDBObject( '$sum', '$rating'));
    DBObject group = new BasicDBObject('$group', groupFields);

    // run aggregation
    AggregationOutput output = db.karma.aggregate( match, project, group );

return [model:[avgkarma:output.getCommandResult()]]