MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

търсене в mongodb агрегиране

Тъй като имате вложени масиви, трябва да приложите $unwind оператор първо, за да денормализира вградените документи, преди да използвате $lookup конвейер (освен ако вече не сте ги изравнявали в операцията си за агрегиране):

db.personaddress.aggregate([
    { "$unwind": "$address" },
    { "$unwind": "$address.location" },
    {
        "$lookup": {
            "from": "places", 
            "localField": "address.location.place._id", 
            "foreignField": "_id", 
            "as": "address.location.place", 
        }
    }
])

което след това може да се реализира като (нетествано):

LookupOperation lookupOperation = LookupOperation.newLookup()
    .from("places")
    .localField("address.location.place._id")
    .foreignField("_id")
    .as("address.location.place");

Aggregation agg = newAggregation(
    unwind("address"),
    unwind("address.location"),
    lookupOperation  
);

AggregationResults<OutputDocument> aggResults = mongoTemplate.aggregate(
    agg, PersonAddressDocument.class, OutputDocument.class
);

Ако вашата версия на Spring Data не поддържа това, заобиколно решение е да приложите AggregationOperation интерфейс за приемане на DBObject :

public class CustomGroupOperation implements AggregationOperation {
    private DBObject operation;

    public CustomGroupOperation (DBObject operation) {
        this.operation = operation;
    }

    @Override
    public DBObject toDBObject(AggregationOperationContext context) {
        return context.getMappedObject(operation);
    }
}

След това внедрете $lookup операция като DBObject в конвейера за агрегиране:

DBObject lookupOperation = (DBObject)new BasicDBObject(
    "$lookup", new BasicDBObject("from", "places")
        .append("localField", "address.location.place._id")
        .append("foreignField", "_id")
        .append("as", "address.location.place")       
);

които след това можете да използвате като:

Aggregation agg = newAggregation(
    unwind("address"),
    unwind("address.location"),
    lookupOperation  
);

AggregationResults<OutputDocument> aggResults = mongoTemplate.aggregate(
    agg, PersonAddressDocument.class, OutputDocument.class
);


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Извличане само на заявения елемент в масив от обекти в колекцията MongoDB

  2. Има ли инструменти за оценка на размера на индекса в MongoDB?

  3. Избягвайте общото ограничение от 16MB

  4. Отидете:Създайте io.Writer интерфейс за регистриране в базата данни mongodb

  5. Как работи операторът за актуализация $set в MongoDB