首页 > 数据库技术 > 详细

MongoDBTemplate多条件查询的问题

时间:2017-12-04 17:59:57      阅读:296      评论:0      收藏:0      [点我收藏+]

问题:

在使用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多条件查询的问题

原文:http://www.cnblogs.com/lanqi/p/7978048.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!