Memecahnya, kueri dengan kata kunci Between
sedang dieksekusi terhadap database MongoDB dengan hasil logis {"createdAt" : {"$gt" : d1, "$lt" : d2}}
jadi ada kemungkinan Anda tidak mendapatkan dokumen yang memiliki createdAt
tanggal termasuk dalam rentang tanggal yang diberikan yaitu d1 < createdAt < d2
karena rentang tanggal yang diberikan tidak memenuhi kriteria. Untuk referensi, ini adalah beberapa interpretasi pada metode kueri
:
Kata kunci yang didukung untuk metode kueri
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}}
Sebagai solusinya, Anda mungkin ingin menggunakan @Query
anotasi. Saya belum menguji ini, tetapi Anda mungkin ingin mencoba contoh penerapan kueri khusus berikut:
public interface UserRepository extends MongoRepository<User, String> {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}
Jika hal di atas tidak berhasil untuk Anda, buat antarmuka khusus dan kelas implementasi Anda untuk menjalankan kueri khusus. Misalnya, buat antarmuka dengan nama yang menambahkan Custom
:
public interface UserRepositoryCustom {
public List<User> findbyCreatedAtBetween(Date from, Date to);
}
Ubah UserRepository
dan tambahkan UserRepositoryCustom
antarmuka yang akan diperluas:
@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {
}
Buat kelas implementasi Anda untuk mengimplementasikan metode yang ditentukan dalam UserRepositoryCustom
antarmuka.
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));
}
}