MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Spring Data Mongo - Perform Distinct, ale nie chce wyciągać osadzonych dokumentów w wynikach

Agregacja pobiera odrębny departments.deptCd wartości (plus inne szczegóły):

db.collection.aggregate( [
{
    $group: { _id: "$departments.deptCd", 
             deptName: { $first: "$departments.deptName" },
             status: { $first: "$departments.status" }
    }
},
{
    $project: { deptCd: "$_id", _id: 0, deptName: 1, status: 1 }
}
] )

Wynik:

{ "deptName" : "Tax Handling Dept", "status" : "A", "deptCd" : "Tax" }

[ EDYTUJ DODAJ ]

Kod przy użyciu Spring Data MongoDB v2.2.7:

MongoOperations mongoOps = new MongoTemplate(MongoClients.create(), "testdb");
Aggregation agg = Aggregation.newAggregation(
    Aggregation.group("departments.deptCd")
        .first("departments.deptName").as("deptName")
        .first("departments.status").as("status"),
    Aggregation.project("deptName", "status")
        .and("_id").as("deptCd")
        .andExclude("_id")
);
AggregationResults<Document> results = mongoOps.aggregate(agg, "collection", Document.class);
results.forEach(System.out::println);



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Aktualizacja kolekcji z innej bazy danych

  2. Optymalizacja środowiska Linux pod kątem MongoDB

  3. MongoDB usuńJeden()

  4. Mongodb - złe zapytanie:BadValue nieznany operator najwyższego poziomu:$gte

  5. Przesyłanie do ObjectId nie powiodło się dla wartości 586cc8b3ea780c071bbe2469 w ścieżce _id dla modelu użytkownika