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

Как да използвате операция $cond в рамката за агрегиране на Spring-MongoDb

Ако използвате текущата версия на Spring Data, която поддържа $cond оператор чрез $project конвейер, тогава това може да се преобразува в (нетествано):

import static org.springframework.data.mongodb.core.aggregation.Aggregation.*;
import static org.springframework.data.mongodb.core.aggregation.ConditionalOperators.Cond.*;
import org.springframework.data.mongodb.core.query.Criteria;

Cond condOperation = ConditionalOperators.when(Criteria.where("start").is("EARLY"))
                                    .thenValueOf("deltastart.start")
                                    .otherwise("deltastart.end");

Aggregation agg = newAggregation(project().and(condOperation).as("start"));
AggregationResults<MyClass> results = mongoTemplate.aggregate(agg, MyClass.class); 
List<MyClass> myList = results.getMappedResults();

За версията на Spring-Data MongoDB, която няма поддръжка за $cond оператор в операцията за агрегиране, има заобиколно решение, което е да се приложи AggregationOperation интерфейс за приемане на DBObject:

public class CustomProjectAggregationOperation implements AggregationOperation {
    private DBObject operation;

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

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

След това имплементирайте $project операция като DBObject в конвейера за агрегиране, която е същата като тази, която имате:

DBObject operation = (DBObject) new BasicDBObject(
    "$project", new BasicDBObject(
         "start", new BasicDBObject(
                "$cond", new Object[]{
                        new BasicDBObject(
                            "$eq", new Object[]{ "$start", "EARLY"}
                        ),
                        "$deltastart.start",
                        "$deltastart.end"
                 }
           )
     )
);

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

TypedAggregation<CustomClass> aggregation = newAggregation(CustomClass.class,
    new CustomProjectAggregationOperation(operation)
);
AggregationResults<CustomClass> result = mongoTemplate.aggregate(aggregation, CustomClass.class); 


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Удостоверяването на MongoDB-CR не бе успешно

  2. Как да вмъкнете няколко елемента наведнъж в колекция MongoDB

  3. Най-добрият начин за моделиране на система за гласуване в MongoDB

  4. Архитектура на приложения, базирана на Mongoose

  5. Mongodb findAndModify възел js