sql >> Database >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAtBetween geeft geen nauwkeurige resultaten terug

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));
    }
}



  1. MongoDB georuimtelijk verschil tussen $near en $within

  2. Korte gebruiksvriendelijke ID voor mongo

  3. Hoe tijdstempel te extraheren uit mongodb objectid in postgres

  4. Waar staat de h in het oplog.rs-document voor?