当我做'更新'时,猫鼬操作字段是'找',为什么?

时间:2016-03-17 12:05:14

标签: node.js mongodb mongoose mongoose-schema mongoose-plugins

我不知道这是否与Mongoose本身或MongoDB驱动程序有关。

这是合约。我想将创建/更新的字段添加到我的模式中。我知道Mongoose可以开箱即用,但我需要使用Unix时间戳而不是日期对象。为了实现这一点,我添加了我在Github(link to plugin)上找到的插件,并将字段类型更改为Number以存储时间戳。

我在插件源代码中找到了这些行:

schema.pre('update', function(next) {
    if (this.op === 'update') {
        this._update = this._update || {};
        this._update[updatedAt] = new Date().getTime;
        this._update['$setOnInsert'] = this._update['$setOnInsert'] || {};
        this._update['$setOnInsert'][createdAt] = new Date().getTime;
    }
    next();
    });

如果我这样做

MyAwesomeModel.update(...., function (e, d) {...});

this.op 将等于'find',而非'update',因此'updated'字段未被更改。

我无法理解为什么会这样,为什么操作是“查找”而不是“更新”。 我试图通过mongoose源代码搜索,但到目前为止我还没有找到答案。

1 个答案:

答案 0 :(得分:0)

您可以放弃插件并使用建议的code hereDate.now()(now()返回Unix时间戳):

var ItemSchema = new Schema({
    name        : { type: String, required: true, trim: true },
    created_at  : { type: Number },
    updated_at  : { type: Number }
});

ItemSchema.pre('save', function(next){
  now = Date.now();
  this.updated_at = now;
  if ( !this.created_at ) {
    this.created_at = now;
  }
  next();
});