MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Comment créer une requête dynamique égale à l'aide d'Apache Camel et de MongoDB ?

Pour commencer, cette déclaration ci-dessus ne sera pas compilée. Il m'a été signalé dans une autre question qu'il y avait une erreur dans la documentation actuelle d'Apache Camel MongoDB et que le setHeader la ligne ci-dessus doit indiquer :

.setHeader(MongoDbConstants.CRITERIA, constant(Filters.eq("name", "Raul Kripalani"))

La façon dont j'ai fini par faire cela était de créer une Expression anonyme :

import com.mongodb.client.model.Filters;
import com.mongodb.BasicDBObject;
import org.bson.conversions.Bson;

@Component
public class NotifyClientRoute extends RouteBuilder {
    public static final String NOTIFY_CLIENT_URI = "direct:notifyClient";

    @Override
    public void configure() throws Exception {

      from(NOTIFY_CLIENT_URI)
        .log("Determining which client gets the deletion request next for DR request '${header.drRequestId}'.")
        .setHeader(MongoDbConstants.CRITERIA, new Expression() {
            @Override
            public <T> T evaluate(Exchange exchange, Class<T> type) {
                String drRequestId = exchange.getIn().getHeader("drRequestId", String.class);

                Bson equalsClause = Filters.eq("drRequestId", drRequestId);

                // Alternatively:
                // Bson equalsClause = new BasicDBObject("drRequestId", new BasicDBObject("$eq", drRequestId));

                return exchange.getContext().getTypeConverter().convertTo(type, equalsClause);
            };
        })
        .to("mongodb:mongoClient?database=mydb&collection=mycollection&operation=findOneByQuery")
        .log("Query returned: '${body}'");
    }
}

Remarque supplémentaire :je n'ai pas trouvé cette instruction de retour dans l'Expression . Je rencontrais des erreurs de type, et j'ai donc regardé ce qu'un autre Apache Camel Expression les implémentations incluses dans les bibliothèques Camel revenaient, et j'ai trouvé cette clause de retour.