MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

Come posso creare una query di equalizzazione dinamica utilizzando Apache Camel e MongoDB?

Per cominciare, quella dichiarazione sopra non verrà compilata. Mi è stato fatto notare in un'altra domanda che c'è un errore nella documentazione corrente di Apache Camel MongoDB e che setHeader la riga sopra dovrebbe leggere:

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

Il modo in cui ho finito per farlo è stato creare un'anomosa Expression :

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 aggiuntiva:non mi è venuta in mente quella dichiarazione di ritorno in Expression . Stavo riscontrando errori di digitazione, quindi ho esaminato un'altra Expression di Apache Camel le implementazioni incluse nelle librerie Camel stavano tornando e ho trovato quella clausola di restituzione.