MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAtBetween non restituisce risultati accurati

Scomponendola, la query con la parola chiave Between viene eseguito sul database MongoDB con il risultato logico {"createdAt" : {"$gt" : d1, "$lt" : d2}} quindi c'è la possibilità che tu non stia ricevendo i documenti che hanno il createdAt data inclusa nell'intervallo di date specificato, ad esempio d1 < createdAt < d2 poiché l'intervallo di date specificato non soddisfa i criteri. Per riferimento, queste sono alcune delle interpretazioni sul metodi di query :

Parole chiave supportate per i metodi di query

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

Come soluzione alternativa, potresti voler utilizzare @Query annotazione. Non l'ho testato, ma potresti provare il seguente esempio di implementazione di query personalizzate:

public interface UserRepository extends MongoRepository<User, String>  {
    @Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
    public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}

Se quanto sopra non funziona per te, crea un'interfaccia personalizzata e la tua classe di implementazione per eseguire la query personalizzata. Ad esempio, crea un'interfaccia con un nome che aggiunga Custom :

public interface UserRepositoryCustom {
    public List<User> findbyCreatedAtBetween(Date from, Date to); 
}

Modifica il UserRepository e aggiungi UserRepositoryCustom interfaccia da estendere:

@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {

}

Crea la tua classe di implementazione per implementare i metodi definiti in UserRepositoryCustom interfaccia.

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