MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Classifique uma matriz e adicione um campo de classificação no MongoDB


Eu acho que seu método é bom, mas apenas altere o results.length para user.length mas se você quiser usar a operação mongoDB, faça assim:
db.collection.aggregate([
  {
    "$sort": {
      "score": -1
    }
  },
  {
    "$group": {
      "_id": "",
      "items": {
        "$push": "$$ROOT"
      }
    }
  },
  {
    "$unwind": {
      "path": "$items",
      "includeArrayIndex": "items.rank"
    }
  },
  {
    "$replaceRoot": {
      "newRoot": "$items"
    }
  },
  {
    "$sort": {
      "score": -1
    }
  }
])

você pode usar lean() e select os alguns campos em find consulta para aumentar o desempenho
async findRank() {
  const users = await User.find({},"_id score").sort({score: -1}).lean()
  for (let index = 0; index < users.length; index++) {
    users[index].rank = index
  }
  return users
}
if you want group by the documents based on name or score ... it's better use mongodb operation