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

Získejte minimální a maximální hodnotu v jediném dotazu v mongodb

Můžete zkusit níže agregaci

$facet vám dá dvě nejnižší a nejvyšší hodnoty pro usages a můžete snadno $project přes ně pomocí $filter operátor

db.collection.aggregate([
  { "$facet": {
    "minUsages": [{ "$sort": { "usages": -1 } }],
    "maxUsages": [{ "$sort": { "usages": 1 } }]
  }},
  { "$addFields": {
    "lowestUsages": {
      "$arrayElemAt": ["$minUsages", 0]
    },
    "highestUsages": {
      "$arrayElemAt": ["$maxUsages", 0]
    }
  }},
  { "$project": {
    "minUsages": {
      "$filter": {
        "input": "$minUsages",
        "as": "minUsage",
        "cond": {
          "$eq": ["$$minUsage.usages", "$lowestUsages.usages"]
        }
      }
    },
    "maxUsages": {
      "$filter": {
        "input": "$maxUsages",
        "as": "maxUsage",
        "cond": {
          "$eq": ["$$maxUsage.usages", "$highestUsages.usages"]
        }
      }
    }
  }}
])

Nebo to můžete jednoduše udělat pomocí find také dotaz

const minUsage = await db.collection.find({}).sort({ "usages": -1 }).limit(1)
const maxUsage = await db.collection.find({}).sort({ "usages": 1 }).limit(1)

const minUsages = await db.collection.find({ "usages": { "$in": [minUsages[0].usages] } })
const maxUsages = await db.collection.find({ "usages": { "$in": [maxUsages[0].usages] } })

Podívejte se sem




  1. mongodb jak vrátit seznam hodnot pouze z vyhledávacího dotazu

  2. Něco jako mezipaměť značek a její dotazování, zda je navrhuje pomocí Redis

  3. Jak mohu zploštit dvojitá pole v mongoDB?

  4. Jak zastavit server mongodb ve Windows?