2013-02-19 99 views
0

如何在Grails 1.3.7中使用Aggregation框架。目前我无法迁移到新版本的grails。我已经尝试过grails mongodb plugin 1.0.0.GA,但它使用的是旧的java驱动程序和gmongo库。我也尝试在build-config.groovy中添加新libs/jar的依赖项,但它仍然在运行时给我提供了集合方法的错误。任何帮助,高度赞赏。grails的Mongodb聚合框架1.3.7

回答

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); 

回报[机型:[avgkarma:output.getCommandResult()]]

+0

你在哪里找到 “:MongoDB的:1.1.0.GA”?你使用哪个回购?我的设置只找到RC3。在这种情况下,我得到java.lang.ClassNotFoundException:org.codehaus.groovy.runtime.BytecodeInterface8。我尝试了两个gmongo 1.0和1.1,并且它们基于groovy 2.x ... – injecteer 2013-07-27 23:11:26

+0

启用groovy 2.1编译器,并确保取消注释公共存储库。 – 2013-07-30 02:01:33

+0

2.1编译器不是一个选项,因为我的项目使用了大约30个其他插件 – injecteer 2013-07-30 13:22:26