【发布时间】:2017-04-24 20:00:33
【问题描述】:
如果我在这里混淆了一些术语,请原谅我,但我正在使用 '$lookup' 运算符在聚合中执行连接操作,如下所示:
db.collection('items').aggregate([{$match: {}},
{
$lookup: {
from: 'usr',
localField: 'usr._id',
foreignField: '_id',
as: '__usr'
}
}, {
$project: {
info: 1,
timestamp: 1,
usr: {
"$arrayElemAt": [ "$__usr", 0 ]
}
}
}], (err, result) => {
res.json(result);
db.close();
});
我正在对聚合结果进行投影,并使用“$arrayElemAt”从结果数组中提取单个“usr”匹配项。 出于显而易见的原因,我不想返回包含敏感信息的整个 'usr' 记录。 我要做的是对使用“$arrayElemAt”操作返回的元素执行投影。 我能够做到这一点的唯一方法是使用原始投影的附加投影,如下所示:
db.collection('items').aggregate([{$match: {}},
{
$lookup: {
from: 'usr',
localField: 'usr._id',
foreignField: '_id',
as: '__usr'
}
}, {
$project: {
info: 1,
timestamp: 1,
usr: {
"$arrayElemAt": [ "$__usr", 0 ]
}
}
}, {
$project: {
info: 1,
timestamp: 1,
usr: {
"username": 1
}
}
}], (err, result) => {
res.json(result);
db.close();
});
有没有办法在没有重复投影的情况下实现这一点?
【问题讨论】:
标签: node.js mongodb mongodb-query aggregation-framework