如何在Grails 1.3.7中使用聚合框架。目前我无法迁移到新版本的grails。我已经尝试过grails mongodb插件1.0.0.GA,但它使用的是旧的java驱动程序和gmongo libs。我还尝试在build-config.groovy中为新的libs / jar添加依赖项,但它仍然在运行时为聚合方法提供错误。任何帮助都非常感谢。
答案 0 :(得分:2)
在你的BuildConfig.groovy中把这个
依赖项{
compile "org.mongodb:mongo-java-driver:2.10.1"
runtime "com.gmongo:gmongo:1.1"
}
然后在插件部分
插件{
compile (":mongodb:1.1.0.GA"){
excludes 'mongo-java-driver', 'gmongo'
}
}
这将更新您的mongodb插件以使用最新的java驱动程序和gmongo。
然后使用聚合框架。实施例
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()]]