MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

MongoRepository findByCreatedAtBetween tidak mengembalikan hasil yang akurat

Memecahnya, kueri dengan kata kunci Between sedang dieksekusi terhadap database MongoDB dengan hasil logis {"createdAt" : {"$gt" : d1, "$lt" : d2}} jadi ada kemungkinan Anda tidak mendapatkan dokumen yang memiliki createdAt tanggal termasuk dalam rentang tanggal yang diberikan yaitu d1 < createdAt < d2 karena rentang tanggal yang diberikan tidak memenuhi kriteria. Untuk referensi, ini adalah beberapa interpretasi pada metode kueri :

Kata kunci yang didukung untuk metode kueri

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

Sebagai solusinya, Anda mungkin ingin menggunakan @Query anotasi. Saya belum menguji ini, tetapi Anda mungkin ingin mencoba contoh penerapan kueri khusus berikut:

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

Jika hal di atas tidak berhasil untuk Anda, buat antarmuka khusus dan kelas implementasi Anda untuk menjalankan kueri khusus. Misalnya, buat antarmuka dengan nama yang menambahkan Custom :

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

Ubah UserRepository dan tambahkan UserRepositoryCustom antarmuka yang akan diperluas:

@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {

}

Buat kelas implementasi Anda untuk mengimplementasikan metode yang ditentukan dalam UserRepositoryCustom antarmuka.

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. Tidak dapat menemukan modul di Nodejs

  2. Bagaimana cara menggunakan $arrayElemAt dan menghapus bidang dari elemen itu di MongoDB $projection?

  3. MongoDB - kesalahan instalasi - wizard pengaturan mongodb berakhir sebelum waktunya

  4. Apakah buruk mengubah tipe _id di MongoDB menjadi integer?

  5. PHP:Apakah desain yang buruk untuk membuat serial objek dan memasukkannya ke dalam database untuk nanti?