Om het uit te splitsen, de zoekopdracht met het trefwoord Between
wordt uitgevoerd tegen de MongoDB-database met het logische resultaat {"createdAt" : {"$gt" : d1, "$lt" : d2}}
dus er is een kans dat u niet de documenten krijgt met de createdAt
datum inclusief binnen het opgegeven datumbereik, d.w.z. d1 < createdAt < d2
omdat het opgegeven datumbereik niet aan de criteria voldoet. Ter referentie, dit zijn enkele van de interpretaties op de zoekmethoden
:
Ondersteunde zoekwoorden voor zoekmethoden
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}}
Als tijdelijke oplossing kunt u de @Query
annotatie. Ik heb dit niet getest, maar u kunt het volgende voorbeeld van de implementatie van aangepaste query's proberen:
public interface UserRepository extends MongoRepository<User, String> {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}
Als het bovenstaande niet voor u werkt, maakt u een aangepaste interface en uw implementatieklasse om de aangepaste query uit te voeren. Maak bijvoorbeeld een interface met een naam waaraan Custom
. wordt toegevoegd :
public interface UserRepositoryCustom {
public List<User> findbyCreatedAtBetween(Date from, Date to);
}
Wijzig de UserRepository
en voeg de UserRepositoryCustom
. toe interface wordt uitgebreid:
@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {
}
Maak uw implementatieklasse om de methoden te implementeren die zijn gedefinieerd in UserRepositoryCustom
interface.
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));
}
}