我不知道这是否与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源代码搜索,但到目前为止我还没有找到答案。
答案 0 :(得分:0)
您可以放弃插件并使用建议的code here和Date.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();
});