首页 文章

使用Java中的QueryDSL和MongoDB创建复杂查询

提问于
浏览
2

我按照本教程设置了MongoDB

http://www.littlelostmanuals.com/2011/09/spring-mongodb-type-safe-queries.html

一切都按预期工作,但现在我陷入了一个我希望能够在多个字段上查询的地方 .

目前,我正在保存每种类型的存储库接口,并且可以在单个字段上搜索 .

public interface StartedEventRepository extends 
    MongoRepository<DatablockStartedEvent, String>,
    QueryDslPredicateExecutor<DatablockStartedEvent> { 

}

以下是单个参数的查询 .

return startedEventRepo
            .findOne(QDatablockStartedEvent.datablockStartedEvent.searchId
                    .eq(searchId));

是否可以创建一个Query对象,我可以在其中说出类似于以下内容的内容 .

if(someName != null){
    query.where(QMyClass.name.eq(someName));
}
if(someTime != null){
    query.where(QMyClass.time.eq(someTime));
}

List result = query.list();

我试过看MongodbQuery但我无法让它工作 . 有任何想法吗?

我看到了一个例子http://www.mkyong.com/mongodb/spring-data-mongodb-update-document/但是它使用了mongoTemplate . 有没有办法通过存储库实现这一点,如果没有,它们是无用的吗?

2 回答

  • 1

    它应该是可能的 . 也许这样的事情

    BooleanBuilder builder = new BooleanBuilder();
    
    if(someName != null){
        builder.and(QMyClass.name.eq(someName));
    }
    if(someTime != null){
        builder.and(QMyClass.time.eq(someTime));
    }
    
    repository.findAll(builder.getValue())
    
  • 6

    在没有使用Spring Data的情况下,我想从阅读这个http://static.springsource.org/spring-data/data-document/docs/1.0.0.M2/reference/html/#mongodb.repositories.queries你只需在你的资源库中声明一个方法名称告诉你的查询结构的方法(这个猜测在同一站点上通过例子4.3得到支持) . 不确定如果您可以生成动态查询,这是唯一一个快速搜索显示的查询 .

相关问题