mongoose如何update某属性的ref

参见mongoose

两集合schema如下:

var personSchema = Schema({
  _id     : Number,
  name    : String,
  age     : Number,
  stories : [{ type: Schema.Types.ObjectId, ref: 'Story' }]
});

var storySchema = Schema({
  _creator : { type: Number, ref: 'Person' },
  title    : String,
  fans     : [{ type: Number, ref: 'Person' }]
});

fans中的一个person取消了对story的喜好(fans的理解不知道对不对)
那么story.fans是数组,可以delete掉该person的数据
这个感觉还比较容易update

如果一个personstory不正确,同时story集合中并不存在该person的正确story
那么是removepersonfield:stories吗?
还是能够将该personfield:stories这个ObjectId类置空?

希望各位能够提供一些建议?

阅读 4.3k
2 个回答

如果我理解正确的话,如何处理需要依据应用的需求。

不过,你假设的第二种情形,如果populate正常的话,通常是不会出现的。

供参考。

新手上路,请多包涵

关注的时候

添加 Stroy 到 Person ($addToSet去重, $push)

    Person.update({
            _id: persionId
        }, {
         $addToSet : { stories: storyId }
        }, function(err, raw)

添加 fans $addToSet(去重), $push(不去重)

Story.update({
        _id: storyId
    }, {
     $addToSet : { fans: persionId }
    }, function(err, raw)

取消关注

删除 Person ($pull)

    Person.update({
            _id: persionId
        }, {
         $pull : { stories: storyId }
        }, function(err, raw)

删除 fans ($pull)

Story.update({
        _id: storyId
    }, {
     $pull : { fans: persionId }
    }, function(err, raw)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题