总值"/>
当用户登录时返回特定用户的总值
正如标题所说,我试图在用户登录时从他们那里获取特定数据并汇总所有数据,然后返回该汇总数据。我试过使用
$match
功能,但没有运气。令人沮丧的部分是我能够在对象数组中成功返回所有数据。更具体地说,下面的代码成功运行并返回一个对象数组:
const runs = await Run.find({ user: req.user.id })
但是这段代码没有,它返回一个空数组:
const cumulativeTotals = await Run.aggregate([
{ $match: { user: req.user.id } },
{
$group: {
_id: null,
totalRunTime: { $sum: '$runTime' },
avgRunTime: { $avg: '$runTime' },
totalRunDistance: { $sum: '$runDistance' },
avgRunDistance: { $avg: '$runDistance' },
avgPace: { $avg: '$avgPace' },
totalHeartRate: { $avg: '$avgHeartRate' },
totalActiveCalories: { $sum: '$activeCalories' },
averageActiveCalories: { $avg: '$activeCalories' },
absoluteTotalCalories: { $sum: '$totalCalories' },
avgTotalCalories: { $avg: '$totalCalories' },
}
}
])
我不确定为什么会这样。它应该返回的是一个数组,其中包含一个对象,该对象填充了其中的所有聚合数据。
我也知道,如果我删除
$match
它将成功聚合运行集合中的所有数据,所以我认为它与此有关。
以下是所有相关代码:
const getRuns = asyncHandler(async (req, res) => {
const runs = await Run.find({ user: req.user.id })
const cumulativeTotals = await Run.aggregate([
{ $match: { user: req.user.id } },
{
$group: {
_id: null,
totalRunTime: { $sum: '$runTime' },
avgRunTime: { $avg: '$runTime' },
totalRunDistance: { $sum: '$runDistance' },
avgRunDistance: { $avg: '$runDistance' },
avgPace: { $avg: '$avgPace' },
totalHeartRate: { $avg: '$avgHeartRate' },
totalActiveCalories: { $sum: '$activeCalories' },
averageActiveCalories: { $avg: '$activeCalories' },
absoluteTotalCalories: { $sum: '$totalCalories' },
avgTotalCalories: { $avg: '$totalCalories' },
}
}
])
if (!runs) {
res.status(400).json({ message: 'No Runs Found for This User' })
return
}
const response = {
runs,
cumulativeTotals
}
res.status(200).json(response)
})
回答如下:
更多推荐
当用户登录时返回特定用户的总值
发布评论