sql >> Databasteknik >  >> NoSQL >> MongoDB

Sortera en array och lägg till ett rangfält i MongoDB

Jag tycker att din metod är bra men ändra bara results.length till user.length men om du vill använda mongoDB-operationen gör så här:

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

du kan använda lean() och select några fält i find fråga för att öka prestandan

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. HBase exempeltabell

  2. Hur man registrerar och ringer ett schema i mongoose

  3. mongoose stringify tar bort tomma element

  4. Iterera över stor samling i MongoDB via vårdata