sql >> Base de Datos >  >> NoSQL >> MongoDB

¿Cómo creo una consulta dinámica de igualdad usando Apache Camel y MongoDB?

Para empezar, esa declaración anterior no se compilará. Se me señaló en otra pregunta que hay un error en la documentación actual de Apache Camel MongoDB y que setHeader la línea de arriba debería decir:

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

La forma en que terminé haciendo esto fue creando una Expression anónima :

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}'");
    }
}

Nota adicional:no se me ocurrió esa declaración de retorno en la Expression . Me encontré con errores de tipo, así que miré qué otra Expression de Apache Camel Las implementaciones incluidas en las bibliotecas de Camel estaban regresando y encontré esa cláusula de retorno.