sql >> Databáze >  >> NoSQL >> MongoDB

vyhledávání v agregaci mongodb

Protože máte vnořená pole, musíte použít $unwind operátor nejprve za účelem denormalizace vložených dokumentů před použitím $lookup potrubí (pokud jste je již nesrovnali ve své agregační operaci):

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

který pak může být implementován jako (netestováno):

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

Pokud vaše verze Spring Data toto nepodporuje, řešením je implementace AggregationOperation rozhraní pro vložení 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);
    }
}

Poté implementujte $lookup operace jako DBObject v agregačním kanálu:

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

který pak můžete použít jako:

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

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


  1. Integrace a služby dostupné z MongoDB pro cloud

  2. Mongodb našel objednávku na vrácení dokumentů

  3. Hledání hodnot pomocí částečného názvu klíče v Redis Sorted Set

  4. mongodb najít pomocí více položek pole