Разбивайки го, заявката с ключовата дума Between
се изпълнява срещу базата данни MongoDB с логически резултат {"createdAt" : {"$gt" : d1, "$lt" : d2}}
така че има шанс да не получите документите, които имат createdAt
дата включително в дадения период от време, т.е. d1 < createdAt < d2
тъй като даденият период от време не отговаря на критериите. За справка това са някои от интерпретациите на методи за заявки
:
Поддържани ключови думи за методи на заявка
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
анотация. Не съм тествал това, но може да опитате следния пример за внедряване на персонализирана заявка:
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));
}
}