MongoDBTemplate多条件查询的问题

Posted Mr-blue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MongoDBTemplate多条件查询的问题相关的知识,希望对你有一定的参考价值。

问题:

在使用Spring Data MongoDB 进行条件查询数据时,发现条件判断不起作用,结果会返回所有的数据。

Criteria criteria = new Criteria();
            criteria.where("shopId")
                    .is(request.getShopId())
                    .and("tradeDate").gte(request.getBeginTradeDate())
                    .lte(request.getEndTradeDate());
            List<ReportInfo> reportInfoList = reportMongoTemplate.
                    find(new Query(criteria), ReportInfo.class,"rept_wallet_refundAndPay");

原因:

经过查看文档和源代码才发现,Criteria的where方法是一个静态工厂方法,它会返回一个实例化的criteria对象,所以就不需要自己new 一个criteria对象了。否则 find(new Query(criteria)里的criteria没有任何判断条件,因此会返回所有的数据。

MongoTemplate 源码

    public static Criteria where(String key) {
        return new Criteria(key);
    }

总结:

还是要看官方的文档和源代码

以上是关于MongoDBTemplate多条件查询的问题的主要内容,如果未能解决你的问题,请参考以下文章

ThinkPHP数据多条件查询代码问题?

关于SQL多条件查询问题: 若其中一条件为空值如何设置忽略该条件而用其它条件组合查询??

python mongoDB 模糊查询(多条件)

SpringDataJpa多条件查询代码封装

多条件查询

用C#多条件查询,并把查询的条件显示在datagridview中