最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

当用户登录时返回特定用户的总值

网站源码admin32浏览0评论

当用户登录时返回特定用户的总值

当用户登录时返回特定用户的总值

正如标题所说,我试图在用户登录时从他们那里获取特定数据并汇总所有数据,然后返回该汇总数据。我试过使用

$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)
})
回答如下:
发布评论

评论列表(0)

  1. 暂无评论