इसे तोड़कर, कीवर्ड के साथ क्वेरी 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));
}
}