Delar upp det, frågan med sökordet Between
exekveras mot MongoDB-databasen med det logiska resultatet {"createdAt" : {"$gt" : d1, "$lt" : d2}}
så det finns en chans att du inte får dokumenten som har createdAt
datum inklusive inom det angivna datumintervallet, dvs. d1 < createdAt < d2
eftersom det givna datumintervallet inte uppfyller kriterierna. För referens dessa är några av tolkningarna på frågemetoder
:
Sökord som stöds för frågemetoder
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}}
Som en lösning kanske du vill använda @Query
anteckning. Jag har inte testat det här men du kanske vill prova följande exempel på implementering av anpassade frågor:
public interface UserRepository extends MongoRepository<User, String> {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}
Om ovanstående inte fungerar för dig, skapa ett anpassat gränssnitt och din implementeringsklass för att köra den anpassade frågan. Skapa till exempel ett gränssnitt med ett namn som lägger till Custom
:
public interface UserRepositoryCustom {
public List<User> findbyCreatedAtBetween(Date from, Date to);
}
Ändra UserRepository
och lägg till UserRepositoryCustom
gränssnitt som ska utökas:
@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {
}
Skapa din implementeringsklass för att implementera metoderna som definieras i UserRepositoryCustom
gränssnitt.
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));
}
}