簡體   English   中英

Mongoose 按數組元素排序

[英]Mongoose Sort by elements in array

我有這樣的文檔:

[
  {
    "_id": "1",
    "name": "Valerio",
    "gender": "M",
    "favorites": []
  },
  {
    "_id": "2",
    "name": "Samad",
    "gender": "M",
    "favorites": ["1", "3", "4"]
  },
  {
    "_id": "3",
    "name": "Ayub",
    "gender": "F",
    "favorites": ["1", "4"]
  },
  {
    "_id": "4",
    "name": "Apour",
    "gender": "M",
    "favorites": ["2"]
  }
]

我想根據 _id 對它們進行排序:“1”存在於收藏夾數組中,如下所示:

[
  {
    "_id": "2",
    "name": "Samad",
    "gender": "M",
    "favorites": ["1", "3", "4"]
  },
  {
    "_id": "3",
    "name": "Ayub",
    "gender": "F",
    "favorites": ["1", "4"]
  },
  {
    "_id": "4",
    "name": "Apour",
    "gender": "M",
    "favorites": ["2"]
  },
  {
    "_id": "1",
    "name": "Valerio",
    "gender": "M",
    "favorites": []
  }
]

這是我正在使用的,但這不是排序,它只是過濾:

User.find({
    $and: [
        { favorites: { $all: [mongoose.Types.ObjectId("1")] } },
        { gender: { $in:['M'] } },
      ],
  })

我真的很感激任何幫助,提前謝謝你。

您可以添加一個臨時鍵,如果該鍵存在則為1 ,如果該鍵不存在則為0 ,並根據該臨時鍵降序排序。

db.collection.aggregate([
  {
    "$addFields": {
      "searchElemExists": {
        "$cond": {
          "if": {
            "$in": [
              "1",  // <-- Value you want to be sorted based on existance
              "$favorites"
            ]
          },
          "then": 1,
          "else": 0
        }
      }
    },
    
  },
  {
    "$sort": {
      "searchElemExists": -1
    }
  },
  {
    "$project": {
      "searchElemExists": 0,
    },
  },
])

樣例數據的游樂場執行

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM