Scomponendola, la query con la parola chiave Between
viene eseguito sul database MongoDB con il risultato logico {"createdAt" : {"$gt" : d1, "$lt" : d2}}
quindi c'è la possibilità che tu non stia ricevendo i documenti che hanno il createdAt
data inclusa nell'intervallo di date specificato, ad esempio d1 < createdAt < d2
poiché l'intervallo di date specificato non soddisfa i criteri. Per riferimento, queste sono alcune delle interpretazioni sul metodi di query
:
Parole chiave supportate per i metodi di query
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}}
Come soluzione alternativa, potresti voler utilizzare @Query
annotazione. Non l'ho testato, ma potresti provare il seguente esempio di implementazione di query personalizzate:
public interface UserRepository extends MongoRepository<User, String> {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}
Se quanto sopra non funziona per te, crea un'interfaccia personalizzata e la tua classe di implementazione per eseguire la query personalizzata. Ad esempio, crea un'interfaccia con un nome che aggiunga Custom
:
public interface UserRepositoryCustom {
public List<User> findbyCreatedAtBetween(Date from, Date to);
}
Modifica il UserRepository
e aggiungi UserRepositoryCustom
interfaccia da estendere:
@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {
}
Crea la tua classe di implementazione per implementare i metodi definiti in UserRepositoryCustom
interfaccia.
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));
}
}