java – MongoRepository findByCreatedAtBetween没有返回准确的
我在Mongo的文档结构是这样的:
db.user.find() { "_id" : ObjectId("560fa46930a8e74be720009a"),"createdAt" : ISODate("2015-10-03T09:47:56.333Z"),"message" : "welcome",} { "_id" : ObjectId("560fa46930a8e723e720009a"),"createdAt" : ISODate("2015-10-03T09:48:25.048Z"),"message" : "thank you" } 当我在Mongo Shell中使用以下查询来查找两个给定时间戳之间的文档时,我得到了正确的结果: db.user.find({createdAt:{$gte:ISODate("2015-10-03T09:40:25.048Z"),$lte:ISODate("2015-10-03T09:50:56.333Z")}}) 我在我的REST服务中使用带有Spring的MongoRepository来使用Java驱动程序.以下是用户存储库: public interface UserRepository extends MongoRepository<User,String> { ArrayList<User> findbyCreatedAtBetween(Date d1,Date d2); } 当我打电话在我的服务中进行以下呼叫时,它不会返回任何结果 但是当我在前一天给出d1时它会返回结果: 关于如何解决这个问题的任何想法?请帮忙! 解决方法
打破它,使用关键字Between查询正在对MongoDB数据库执行逻辑结果{“createdAt”:{“$gt”:d1,“$lt”:d2}}所以有可能你是没有得到在给定日期范围内具有createdAt日期的文档,即d1< createdAt< d2,因为给定的日期范围不符合标准.作为参考,这些是对
query methods的一些解释:
支持查询方法的关键字 Keyword Sample Logical result After findByBirthdateAfter(Date date) {"birthdate" : {"$gt" : date}} Before findByBirthdateBefore(Date date) {"birthdate" : {"$lt" : date}} Between findByAgeBetween(int from,int to) {"age" : {"$gt" : from,"$lt" : to}} 作为解决方法,您可能希望使用 public interface UserRepository extends MongoRepository<User,String> { @Query(value = "{ 'createdAt' : {$gte : ?0,$lte: ?1 }}") public ArrayList<User> findbyCreatedAtBetween(Date from,Date to); } 如果上述方法不适合您,请创建自定义界面和实现类以执行自定义查询.例如,创建一个名称附加自定义的接口: public interface UserRepositoryCustom { public List<User> findbyCreatedAtBetween(Date from,Date to); } 修改UserRepository并添加要扩展的UserRepositoryCustom接口: @Repository public interface UserRepository extends UserRepositoryCustom,MongoRepository { } 创建实现类以实现UserRepositoryCustom接口中定义的方法. public class UserRepositoryImpl implements UserRepositoryCustom { @Autowired MongoTemplate mongoTemplate; @Override public ArrayList<User> findbyCreatedAtBetween(Date from,Date to) { return mongoTemplate.find( Query.addCriteria(Criteria.where("createdAt").gte(from).lte(to)); } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |