MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAtMiędzy brakiem zwracania dokładnych wyników

Rozbijając to, zapytanie ze słowem kluczowym Between jest wykonywane na bazie danych MongoDB z logicznym wynikiem {"createdAt" : {"$gt" : d1, "$lt" : d2}} więc istnieje szansa, że ​​nie otrzymasz dokumentów, które mają createdAt data włącznie w podanym zakresie dat, tj. d1 < createdAt < d2 ponieważ podany zakres dat nie spełnia kryteriów. Dla porównania, oto niektóre z interpretacji metody zapytań :

Obsługiwane słowa kluczowe dla metod zapytań

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

Jako obejście możesz użyć @Query adnotacja. Nie testowałem tego, ale możesz wypróbować następujący przykład implementacji zapytania niestandardowego:

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

Jeśli powyższe nie działa, utwórz niestandardowy interfejs i klasę implementacji, aby wykonać niestandardowe zapytanie. Na przykład utwórz interfejs o nazwie z dopiskiem Custom :

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

Zmodyfikuj UserRepository i dodaj UserRepositoryCustom interfejs do rozbudowy:

@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {

}

Utwórz swoją klasę implementacji, aby zaimplementować metody zdefiniowane w UserRepositoryCustom interfejs.

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. MongoDB:Jak wyłączyć rejestrowanie ostrzeżenia:ClientCursor::staticYield nie może odblokować b/c blokady rekurencyjnej?

  2. Jaki jest pożytek z pliku mongo.lock?

  3. Przenieś element z jednej tablicy do drugiej w tym samym dokumencie MongoDB

  4. Prosta kontrola stanu HTTP/TCP dla MongoDB

  5. eksport mongo SyntaxError:brak; przed oświadczeniem @(shell):1:14