sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAtBetween returnerar inte korrekta resultat

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



  1. Redis:Är ZADD bättre än O(logN) när det infogade elementet är i början eller slutet?

  2. 2 sätt att ersätta en delsträng i MongoDB

  3. MongoDB Hitta prestanda:enstaka sammansatta index VS två enstaka fältindex

  4. Vad är resultatet av en filström?