MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Uzyskaj minimalną i maksymalną wartość w jednym zapytaniu w mongodb

Możesz spróbować poniżej agregacji

$facet da ci dwie najniższą i najwyższą wartość dla usages i możesz łatwo $project za ich pośrednictwem za pomocą $filter operator

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"]
        }
      }
    }
  }}
])

Możesz też po prostu zrobić to za pomocą find zapytanie również

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] } })

Spójrz tutaj




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak utworzyć użytkownika w MongoDB v3.0.5?

  2. Wydaje się, że wyniki MapReduce są ograniczone do 100?

  3. Osadzona populacja mangusty

  4. Mongodb - zaktualizuj częściową liczbę dokumentów

  5. Przechowuj dane lokalizacji w dokumencie Mongodb