分解一下,带有关键字的查询Between
正在针对 MongoDB 数据库执行,并得出逻辑结果{"createdAt" : {"$gt" : d1, "$lt" : d2}}
因此您有可能无法获得包含以下内容的文件createdAt
给定日期范围内的日期,即d1 < createdAt < d2
因为给定的日期范围不满足标准。以下是一些关于这个问题的解释,仅供参考查询方式 http://docs.spring.io/spring-data/mongodb/docs/current/reference/html/#mongodb.repositories.queries:
查询方法支持的关键字
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}}
作为解决方法,您可能需要使用@Query http://docs.spring.io/spring-data/mongodb/docs/current/reference/html/#mongodb.repositories.queries.json-based注解。我还没有对此进行测试,但您可能想尝试以下自定义查询实现示例:
public interface UserRepository extends MongoRepository<User, String> {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}
如果上述方法不适合您,请创建自定义接口和实现类来执行自定义查询。例如,创建一个名称附加的接口Custom
:
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));
}
}