sql >> Databáze >  >> NoSQL >> MongoDB

Seřaďte pole a přidejte pole hodnocení v MongoDB

Myslím, že vaše metoda je dobrá, ale stačí změnit results.length na user.length ale pokud chcete používat provoz mongoDB, postupujte takto:

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

můžete použít lean() a select některá pole v find dotaz pro zvýšení výkonu

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. MongoDB $lookup Objectid získat prázdné pole?

  2. Jak provádět vyhledávání zástupných znaků v MongoDB pomocí Java

  3. Jaký je výchozí časový limit relace a jak jej nakonfigurovat při použití jarní relace s Redis jako backend

  4. Optimalizace spojení dotazů Mongodb