乐趣区

关于数据库:Mongoose无法更新时间戳

Mongose 是为 node.js 开发的 MongoDB 对象模型,它基于 schema 来解决利用的数据模型,开箱即用。

schema 中的工夫戳

const mongoose = require('mongoose');

const BlogSchema = new mongoose.Schema({id: { type: Number},
  title: {type: String},
  category: {type: String},
  tags: {type: String},
  abstract: {type: String},
  content: {type: String},
  creator: {type: String},
  status: {type: Number},
  top: {type: Number, default: 1}, // 1. 非置顶 2. 置顶
  view_count: {type: Number},
}, {
  timestamps: {
    createdAt: 'create_time',
    updatedAt: 'update_time',
  },
});

如上定义的 BlogSchema,timestamps 能够帮忙咱们在创立新的数据(或者更新)时主动保护创立工夫和更新工夫。

那么问题来了

然而,当咱们想要更新创立工夫时会遇到无奈更新的问题(尽管很少有人会更新创立工夫 …)。

查阅 Mongoose 官网,在这里找到了答案:

// Mongoose blocked changing createdAt and set its own updatedAt, ignoring
// the attempt to manually set them.

意思是如果咱们开启了主动生成工夫戳,那么当咱们应用 findOneAndUpdate(), updateMany(),updateOne() 这些办法更新 create_time 是不会失效的,会被 Mongoose 疏忽。

解决办法

const mongoose = require('mongoose');

const BlogSchema = new mongoose.Schema({id: { type: Number},
  title: {type: String},
  category: {type: String},
  tags: {type: String},
  abstract: {type: String},
  content: {type: String},
  creator: {type: String},
  status: {type: Number},
  top: {type: Number, default: 1}, // 1. 非置顶 2. 置顶
  view_count: {type: Number},
  create_time: {type: Date, default: Date.now}
}, {
  timestamps: {
    // createdAt: 'create_time',
    createdAt: false,
    updatedAt: 'update_time',
  },
});

在 Schema 字段中减少了最初一行 create_time: {type: Date, default: Date.now}

timestamps 中 createdAt: false, 示意不主动生成工夫戳,咱们手动保护。而 update_time 还是由 Mongoose 替咱们保护。

这样,再次尝试更新时,create_time 就会被设置为你冀望的值。

退出移动版