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

Desain aplikasi mongodb data musim semi dan agregasi data

Setiap kali Spring Data Mongo tidak memiliki AggregationOperation yang Anda butuhkan (untuk mereproduksi $addFields , $redact ...), solusinya (beberapa orang mungkin mengatakan solusi cepat dan kotor) adalah meneruskan agregasi mentah ke Spring, menggunakan langsung alat com.mongodb.client :

String collectionName = mongoTemplate.getCollectionName(Payment.class);
MongoCollection<Document> collection = mongoClient.getDatabase(mongoTemplate.getDb().getName()).getCollection(collectionName);

AggregateIterable<Document> ai = collection.aggregate(Arrays.asList(
    Document.parse(/* { "group" : { ... } } */)))

MongoCollection.aggregate() diteruskan ke pipeline agregasi sebagai List<Document> (sebenarnya List<? extends Bson> dalam bentuk mentah seperti yang disarankan di atas menggunakan Document.parse(), dan tentu saja Anda juga dapat menggunakan new Document() untuk membuatnya terlihat lebih seperti kode OOP yang tepat. Saya cenderung menggunakan bentuk mentah ketika agregasi mentahnya kompleks atau karena banyak komponen bersarang untuk Dokumen bersarang terlalu bertele-tele bagi saya, tapi itu masalah selera.

PEMBARUAN 2020.

Gunakan solusi ini alih-alih. Dengan ini, mudah untuk menggunakan AggregationOperation yang disediakan oleh Spring dan tahapan agregasi "mentah" Anda sendiri di tempat yang sama.




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Penggunaan collation di mongodb $regex

  2. Driver MongoDB dan Java:abaikan kasus dalam kueri

  3. Kelompokkan menurut interval tanggal

  4. Apakah ada cara untuk memaksa mongodb menyimpan indeks tertentu di ram?

  5. Cara membuat bidang kenaikan otomatis