MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAt बीच में सटीक परिणाम नहीं लौटाता

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



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मोंगो - क्वेरी, एंबेडेड दस्तावेज़ डॉट नोटेशन को छोड़कर मेल नहीं खाता

  2. MongoDB स्कीमा प्रदर्शन अनुकूलन

  3. Orbeon में MongoDB डेटा स्रोत कैसे जोड़ें

  4. MongoDB खोज का उपयोग करके स्वत:पूर्ण सुविधा लागू करें

  5. MongoDB:'_id' के बजाय 'id' आउटपुट