如果未在模型中填充,则按数组长度排序

时间:2013-02-17 17:53:18

标签: node.js mongodb mongoose

所以,我有两个猫鼬模型:

User: {
   name: String,
   ..........
   locations: []
}

Location: {
   title: String,
   .............
   owner: {
      type: Schema.Types.ObjectId,
      ref: 'User'
   }
}

我在节点中的查找功能,对于User来说就是:

api.find = function(filter, sort, skip, limit){
    var callback = arguments[arguments.length - 1];
    filter = treatFilter(filter);
    sort = treatSort(sort);
    if(callback && typeof callback === 'function'){
        User.find(filter).sort(sort).skip(skip).limit(limit).exec(function(err, users){
            if(users.length === 0){
                callback(err, users);
            }
            for(var i = 0, complete = 0; i < users.length; i++){
                (function(idx){
                    var user = users[idx];
                    var id = user.id;
                    Location.find({owner: id}, function(err, locations){
                        user.locations = locations;
                        if(++complete === users.length){
                            callback(err, users);
                        }
                    });
                })(i);
            }
        });
    }
};

我的sort对象必须是什么样的,所以我可以根据位置数进行排序?

谢谢,如果您有任何疑问,我将很乐意解释我的代码

1 个答案:

答案 0 :(得分:2)

根据这篇文章(mongoose - sort by array length

你必须维护一个单独的字段来存储位置数 - 不是太多的开销,但有点烦人的维护

我研究了用虚拟场进行排序,但这也是不可能的,可能效率很低......