My Mongo Shell Script:
db.getCollection('order').aggregate([
{ $match: { clientId: "[email protected]" } },
{ $lookup: { from: 'ordereddevice', localField: 'id', foreignField: 'order', as: 'orderedDevices' } }
])
What I'm using is like this:
MongoClientURI connectionString = new MongoClientURI("mongodb://localhost:27017");
MongoClient mongoClient = new MongoClient(connectionString);
MongoDatabase database = mongoClient.getDatabase("db_name");
MongoCollection < Document > collection = database.getCollection("order");
List < Document > pipeline = Arrays.asList(new Document().append("$match", new Document().append("clientId", "[email protected]")), new Document().append("$lookup", new Document().append("from", "ordereddevice").append("localField", "id").append("foreignField", "order").append("as", "orderedDevices")));
Block < Document > printBlock = new Block < Document > () {
@Override public void apply(final Document document) {
System.out.println(document.get("_id"));
}
};
collection.aggregate(pipeline).forEach(printBlock);
But it will reconnect MongoDB, So I'm looking for a way to use MongoTemplate to do it
Thanks for the document, just Finish it myself! lol
@Autowired
MongoTemplate mongoTemplate;
@Override
public List<OrderedDeviceByOrderId> findOrderedDeviceByOrderId(String clientid) {
AggregationOperation lookup = Aggregation.lookup("ordereddevice","_id","order","Devices");
AggregationOperation match = Aggregation.match(Criteria.where("clientId").is(clientid));
Aggregation agg = Aggregation.newAggregation(match, lookup);
AggregationResults<OrderedDeviceByOrderId> results = mongoTemplate.aggregate(agg, "order", OrderedDeviceByOrderId.class);
List<OrderedDeviceByOrderId> orderedDeviceByOrderId = results.getMappedResults();
orderedDeviceByOrderId.forEach(s -> System.out.println(s));
return orderedDeviceByOrderId;
}