首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mongoose获取数据位置

Mongoose获取数据位置
EN

Stack Overflow用户
提问于 2020-12-29 23:36:07
回答 1查看 133关注 0票数 1

我正在使用此代码来获取我的用户排行榜

代码语言:javascript
复制
var data = await db.models.user
    .find({ points: { $ne: 0 } })
    .collation({locale: "en_US", numericOrdering: true})
    .sort('-points')
    .limit(10)
    .skip(page*10-10)

但我找不到如何让用户在所有排行榜上的位置。我怎么才能得到它呢?

EN

回答 1

Stack Overflow用户

发布于 2020-12-30 17:20:28

我不认为有任何好的途径或方法可以做到这一点,但你仍然想这样做,然后尝试使用aggregate()$unwind stage,

  • $match您的conditions
  • $sort by points在降序
    • $match by null,并将docs
    • $unwind中所有文档的数组解构并传递includeArrayIndex: 'position'这将在每个文档中创建一个有序索引字段position,从零(0)开始,points$limit

代码语言:javascript
复制
var data = await db.models.user.aggregate([
  { $match: { points: { $ne: 0 } } },
  { $sort: { points: -1 } },
  {
    $group: {
      _id: null,
      docs: { $push: "$$ROOT" }
    }
  },
  {
    $unwind: {
      path: "$docs",
      includeArrayIndex: "position"
    }
  },
  { $skip: 10 },
  { $limit: page*10-10 }
])

Playground

这可能是繁重的操作,在大数据中可能需要更多的执行时间!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65494673

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档