MongoDB 中有什么简单办法做多字段 join?
JOIN 在 SQL 是中很基本的运算,但 MongoDB 却没有直接提供,要用 $lookup 对付,但对多个字段关联时就很麻烦。比如这一段: db.getCollection(‘c1’).aggregate([ { $lookup: { from: “c2”, localField: “user1”, foreignField: “user1”, as: “R” } }, {$unwind :“$R”}, { $project: { user1:1, user2:1, income:1, output:‘$R.output’, mid: {$cond: [ { $eq: [ ‘$user2’, ‘$R.user2’] }, 1, 0 ] } } }, {$match : { “$and”: [ {mid : 1}, {income:{ $gte: 0.30}} ] }} ]) 也就是相当于 SELECT S.* FROM C1 S LEFT JOIN C2 R ON S.user1 =R.user1 AND S.user2 =R.user2 WHERE R.income>0.30 这句简单的 SQL。 因为 $lookup 仅支持单字段条件,多字段关联要用 $unwind 将数据拆分,再用 $project: 获取字段,还要用把关联条件拼到过滤条件,整个过程都很繁琐。