Rozbijając to, zapytanie ze słowem kluczowym Between
jest wykonywane na bazie danych MongoDB z logicznym wynikiem {"createdAt" : {"$gt" : d1, "$lt" : d2}}
więc istnieje szansa, że nie otrzymasz dokumentów, które mają createdAt
data włącznie w podanym zakresie dat, tj. d1 < createdAt < d2
ponieważ podany zakres dat nie spełnia kryteriów. Dla porównania, oto niektóre z interpretacji metody zapytań
:
Obsługiwane słowa kluczowe dla metod zapytań
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}}
Jako obejście możesz użyć @Query
adnotacja. Nie testowałem tego, ale możesz wypróbować następujący przykład implementacji zapytania niestandardowego:
public interface UserRepository extends MongoRepository<User, String> {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}
Jeśli powyższe nie działa, utwórz niestandardowy interfejs i klasę implementacji, aby wykonać niestandardowe zapytanie. Na przykład utwórz interfejs o nazwie z dopiskiem Custom
:
public interface UserRepositoryCustom {
public List<User> findbyCreatedAtBetween(Date from, Date to);
}
Zmodyfikuj UserRepository
i dodaj UserRepositoryCustom
interfejs do rozbudowy:
@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {
}
Utwórz swoją klasę implementacji, aby zaimplementować metody zdefiniowane w UserRepositoryCustom
interfejs.
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));
}
}