在mongoose中对嵌套数组进行排序

You*_*ere 2 javascript arrays mongoose mongodb node.js

我有一个PlaylistShema与阵列或音乐.在这一系列的音乐中,我有一个ObjectId(谁参考音乐收藏),一个addedAt和一个title.

PlaylistShema

var PlaylistSchema = new Schema({
  title: {type : String, default : '', trim : true},
  user: {type : Schema.ObjectId, ref : 'User'},

  musics : [{ 
    musicId : {type : Schema.ObjectId , ref : 'Music'},
    title : {type : String},
    addedAt : {type : Date, default : Date.now}
  }],

  tags : { type : [], get : getTags, set : setTags},
  createdAt  : {type : Date, default : Date.now}
})
Run Code Online (Sandbox Code Playgroud)

我有一个静态加载播放列表:

加载功能

  load: function (id, cb) {
    this.findOne({ _id : id })
      .populate('user', 'name email username')
      .populate('musics.musicId')
      .exec(cb)
  }
Run Code Online (Sandbox Code Playgroud)

我想通过addedAt... 来排序我的音乐... 但我不能这样做,.populate('musics.musicId', { sort: { 'addedAt': 'desc' } })因为这不是addedAt...

当涉及到嵌套数组时,我对populate非常困惑...

谢谢 !

MusicShema

var MusicSchema = new Schema({
  title: {type : String, default : '', trim : true}
})
Run Code Online (Sandbox Code Playgroud)

Wir*_*rie 5

您无法直接在Mongoose中对数组进行排序.您可以使用toObject(文档)和Array sort方法克隆数据并将其排序为JavaScript对象:

Playlist.load(function(err, playList) {
    var pl = playList.toObject();
    pl.musics.sort(function(m1, m2) { return m1.addedAt - m2.addedAt; });
    // pl contains the playlist now 
});
Run Code Online (Sandbox Code Playgroud)

  • 你应该问一个新问题. (2认同)