在MongoDB中,聚合管道查詢是一種強大的數據處理功能,它允許你對數據進行各種操作,如過濾、投影、分組、排序等。要在MongoDB中使用聚合管道查詢進行轉換,你需要使用$project
階段來指定你想要保留和轉換的字段。
以下是一個簡單的示例,說明如何使用聚合管道查詢進行轉換:
假設我們有一個名為students
的集合,其中包含以下文檔:
[
{
"_id": 1,
"name": "Alice",
"age": 20,
"scores": [80, 90, 70]
},
{
"_id": 2,
"name": "Bob",
"age": 22,
"scores": [85, 95, 75]
},
{
"_id": 3,
"name": "Charlie",
"age": 21,
"scores": [90, 80, 85]
}
]
現在,我們想要將這些文檔轉換為一個只包含name
和averageScore
字段的集合。我們可以使用以下聚合管道查詢:
db.students.aggregate([
{
$project: {
_id: 0, // 不包含_id字段
name: 1, // 包含name字段
averageScore: { // 計算平均分
$avg: "$scores" // 使用$avg操作符計算scores數組的平均值
}
}
}
])
這個查詢將返回以下結果:
[
{
"name": "Alice",
"averageScore": 80
},
{
"name": "Bob",
"averageScore": 85
},
{
"name": "Charlie",
"averageScore": 85
}
]
在這個示例中,我們使用$project
階段來指定我們想要保留的字段(name
)以及計算新字段(averageScore
)的表達式($avg: "$scores"
)。這樣,我們就實現了數據的轉換。