今天需要在MongoDB里做一个统计功能,同时要按日期进行过滤。查了很久都没有找到合适的资料,感觉相关资料太少了。经过苦逼地钻研,终于把问题搞定了。现归纳如下:
MongoDB中的数据示例:
方法一:通过构造BasicDBObject对象来进行查询
int startYear=2015,endYear=2016;
int startMonth=12,endMonth=1;
int startDay=1,endDay=1;
BasicDBObject query= new BasicDBObject("applydate", new BasicDBObject("$gte", new Date(startYear - 1900, startMonth - 1, startDay)).append("$lt", new Date(endYear - 1900, endMonth -1, endDay)));//因为无法确知当前月有多少天,所以就从当月的1号(包含)计到下月1号(不包含)
int iCount = cltApplies.find(query).count();
System.out.println(iCount);
经测试上述代码执行完毕后iCount为9。也就是在2016-1-1至2016-1-31期间有9条记录。
方法二:通过BasicDBObjectBuilder对象来查询&