javascript - 根据自己变量的值条件添加聚合
问题描述
我有两个函数可以使用聚合从 monga 获取数组。功能完全一样,除了一个管道 - “match ({startTime: {$ gte: start}})”。我怎样才能留下一个函数并仅通过“开始”变量的存在添加一个“数学”,这是一个日期过滤器?
let groupedByUserSessions
if (lastDay) {
const start = getDateFromString(lastDay);
groupedByUserSessions = await getValuesByDate(start)
} else {
groupedByUserSessions = await getAllValues();
}
function getValuesByDate(start) {
return Sessions.aggregate()
.match({ startTime: { $gte: start } })
.group({
_id: { departament: "$departament", userAdName: "$userAdName" },
cleanTime: { $sum: { $subtract: ["$commonTime", "$idlingTime"] } }
})
.group({
_id: { departament: "$_id.departament"},
users: { $push: {value: '$cleanTime', name: '$_id.userAdName'} },
commonCleanTime: { $sum: "$cleanTime" }
})
.project({
departament: '$_id.departament',
users: '$users',
commonCleanTime: '$commonCleanTime',
performance: { $divide: [ "$commonCleanTime", { $size: "$users" }] }
});
}
解决方案
您可以将管道分成“头”和“尾”,并在start
给出参数时以不同的方式构造头:
function getValuesByDate(start) {
let agg = Sessions.aggregate();
if (start) {
agg = agg.match({ startTime: { $gte: start } });
}
return agg
.group({
_id: { departament: '$departament', userAdName: '$userAdName' },
cleanTime: { $sum: { $subtract: ['$commonTime', '$idlingTime'] } },
})
.group({
_id: { departament: '$_id.departament' },
users: { $push: { value: '$cleanTime', name: '$_id.userAdName' } },
commonCleanTime: { $sum: '$cleanTime' },
})
.project({
departament: '$_id.departament',
users: '$users',
commonCleanTime: '$commonCleanTime',
performance: { $divide: ['$commonCleanTime', { $size: '$users' }] },
});
}
推荐阅读
- python - 将多索引数据帧转换为 json
- html - 访问网站并从服务器下载文件
- python - 为什么我的堆积条形图中缺少条形 - Python w/matplotlib
- jprofiler - JProfiler 代理:将通信套接字绑定到 AIX 平台上的特定网络接口
- oracle - 从忽略最后两行问题插入选择
- node.js - Husky 没有被 git 事件触发
- javascript - Firebase 函数错误 - firebase.functions 不是函数
- r - R中的重组日期
- unity3d - 检查对象是否全部绘制
- javascript - Callapse 列表:仅保持打开活动的打开