在MongoDB中,可以使用以下方法來查詢三個表:
db.Table1.aggregate([
{
$lookup: {
from: "Table2",
localField: "field1",
foreignField: "field2",
as: "joinTable2"
}
},
{
$lookup: {
from: "Table3",
localField: "joinTable2.field3",
foreignField: "field4",
as: "joinTable3"
}
}
])
上述示例中,首先使用$lookup操作符將Table1和Table2連接起來,然后再將連接結果與Table3連接起來。
var table2Ids = db.Table1.find({}).map(function(doc) { return doc.field1; });
var table3Ids = db.Table2.find({ field2: { $in: table2Ids } }).map(function(doc) { return doc.field3; });
var result = db.Table3.find({ field4: { $in: table3Ids } });
上述示例中,首先使用第一個查詢獲取Table1的field1字段,然后使用這些字段在第二個查詢中匹配Table2的field2字段,最后使用匹配結果在第三個查詢中匹配Table3的field4字段。
總的來說,聚合框架提供了更靈活和強大的查詢方式,而嵌套查詢則相對簡單一些。根據具體的需求和數據結構,您可以選擇適合的方法來查詢三個表。