У меня есть одна коллекция с именем assets, которая содержит документы в 2+ форматах, ParentObject и ChildObject. В настоящее время я связываю ParentObject с ChildObject двумя запросами. Можно ли это сделать с помощью агрегированного запроса?
Родительский объект
{
"_id" : {
"oid" : "ParentFooABC",
"brand" : "acme"
},
"type": "com.ParentClass",
"title": "Title1234",
"availableDate": Date,
"expirationDate": Date
}
дочерний объект
{
"_id" : {
"oid" : "ChildFoo",
"brand" : "acme"
},
"type": "com.ChildClass",
"parentObject": "ParentFooABC",
"title": "Title1234",
"modelNumber": "8HE56",
"modelLine": "Metro",
"availableDate": Date,
"expirationDate": Date,
"IDRequired": true
}
В настоящее время я фильтрую данные следующим образом
val parent = db.asset.find(MongoDBObject("_id.brand": MongoDBObject($eq: "acme")),MongoDBObject("type":"com.ParentClass"))
val children = db.asset.find(MongoDBObject("_id.brand": MongoDBObject($eq: "acme")),MongoDBObject("type":"com.ChildClass"), MongoDBObject("parentObject": "${parent._id.oid}"))
if(childs.nonEmpty) {
//I have confirmed this parent has a child associated and should be returned
val childModelNumbers = childs.map(child -> child.modelNumber)
val response = ResponseObject(parent, childModelNumbers)
}
Могу ли я сделать это в агрегированном запросе?
Обновлено:
Версия Mongo: версия БД v2.6.11
Язык: Скала
Драйвер: Casbah 2.8.1