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

Hvordan opretter jeg en dynamisk lig-forespørgsel ved hjælp af Apache Camel og MongoDB?

For det første vil denne erklæring ovenfor ikke kompilere. Det blev påpeget for mig i et andet spørgsmål, at der er en fejl i den aktuelle Apache Camel MongoDB-dokumentation, og at setHeader linjen ovenfor skal lyde:

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

Måden jeg endte med at gøre dette på var ved at oprette et anonymt 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}'");
    }
}

Yderligere bemærkning:Jeg kom ikke med den returerklæring i Expression . Jeg løb ind i typefejl, og så jeg kiggede på, hvad en anden Apache Camel Expression Implementeringer inkluderet i Camel-bibliotekerne vendte tilbage, og jeg fandt den returklausul.




  1. Sådan kører du rå mongodb-kommandoer fra pymongo

  2. Sikkerhedskopiere meteordatabase med mongodump?

  3. mongodb gemmer ikke alle data

  4. Hvordan forbedrer man Redis-serverens CPU-brug?