MongoDB предоставляет возможность агрегации данных из двух коллекций с помощью операторов $lookup и $unwind.
Оператор $lookup позволяет объединять данные из двух коллекций на основе одного или нескольких полей. Пример использования:
db.collection.aggregate([
{
$lookup:
{
from: "otherCollection",
localField: "field",
foreignField: "otherField",
as: "newField"
}
}
])
В данном примере мы объединяем коллекцию "collection" с коллекцией "otherCollection". При объединении мы сопоставляем поле "field" из коллекции "collection" с полем "otherField" из коллекции "otherCollection". Результат объединения записывается в новое поле "newField" в каждом документе коллекции "collection".
Оператор $unwind позволяет развернуть массивы документов, чтобы можно было проводить агрегацию данных. Пример использования:
db.collection.aggregate([
{ $unwind: "$arrayField" }
])
В данном примере мы разворачиваем массив "arrayField" в каждом документе коллекции "collection". Это позволяет нам проводить агрегацию данных на уровне элементов массива.
Если вам нужно объединить данные из двух коллекций и провести агрегацию данных, вы можете использовать операторы $lookup и $unwind совместно:
db.collection.aggregate([
{
$lookup:
{
from: "otherCollection",
localField: "field",
foreignField: "otherField",
as: "newField"
}
},
{ $unwind: "$newField" },
{
$group: {
_id: "$_id",
total: { $sum: "$newField.value" }
}
}
])
В данном примере мы сначала объединяем коллекции "collection" и "otherCollection" по полю "field" и "otherField" соответственно. Затем мы разворачиваем результат объединения с помощью оператора $unwind. Наконец, мы проводим агрегацию данных с помощью оператора $group, суммируя значения поля "value" из развернутого массива.
Таким образом, с помощью операторов $lookup и $unwind в MongoDB вы можете легко объединять и агрегировать данные из двух коллекций. Это предоставляет богатые возможности для анализа и обработки данных в ваших приложениях.