sql >> Database >  >> NoSQL >> MongoDB

Sorteer een array en voeg een rangveld toe in MongoDB

Ik denk dat je methode goed is, maar verander gewoon de results.length naar user.length maar als u de mongoDB-bewerking wilt gebruiken, doet u dit als volgt:

db.collection.aggregate([
  {
    "$sort": {
      "score": -1
    }
  },
  {
    "$group": {
      "_id": "",
      "items": {
        "$push": "$$ROOT"
      }
    }
  },
  {
    "$unwind": {
      "path": "$items",
      "includeArrayIndex": "items.rank"
    }
  },
  {
    "$replaceRoot": {
      "newRoot": "$items"
    }
  },
  {
    "$sort": {
      "score": -1
    }
  }
])

je kunt lean() . gebruiken en select de enkele velden in find query om de prestaties te verbeteren

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



  1. Connect-mongo-sessies worden niet automatisch verwijderd

  2. Query MongoDB met lengtecriteria

  3. Bash-shellscript krijgt geen verbinding met MongoDB, zelfs als de status actief is

  4. hoe geoNear in nodejs te gebruiken?