1

我有一个猫鼬模式,例如:

var postSchema = new Schema({
    ...
    tags : [{ type: Schema.Types.ObjectId, ref: 'Tag' }]
});

我正在尝试实现一个静态方法,该方法返回具有特定标签的帖子。就像是:

postSchema.statics.searchByTag = function searchByTag (tag, cb) {
  return this.find().populate('tags')
             .where("tags contains the element tag")
             .exec(cb);
};

问题:

  1. 我可以在静态方法中使用填充吗?
  2. 检查“标签”是否包含“标签”的最佳方法是什么?

谢谢您的帮助。

4

1 回答 1

4

这就是我的答案/解决方案:1)是的,填充在静态方法中工作;2)这就是我解决问题的方法,可能不是最有效的方法,但它有效:

postSchema.statics.searchByTag = function searchByTag (tagId, cb) {
    var Posts = [];
    this.find({})
    .populate('author tags')
    .exec(function(err,posts){
    if(err){
        cb(err);
    }else{
        posts.forEach(function(post){
        post.tags.forEach(function(tag){
            if(new String(tag._id).valueOf() == new String(tagId).valueOf()){
            Posts.push(post);
            }
        });         
        });
        cb(null,Posts);
    }
    });
}
于 2014-11-25T19:47:52.827 回答