MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAtBetween не връща точни резултати

Разбивайки го, заявката с ключовата дума 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. Вероятност за сблъсък на ObjectId срещу UUID в голяма разпределена система

  2. Как да използвате $ позиционен оператор в MongoDB C# драйвер версия 2

  3. Проектирайте елемент, върнат с $arrayElemAt

  4. Полета за заявки в колекция MongoDB.

  5. Как мога да редактирам/преименувам ключове по време на json.load в python?