关于数据库: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就会被设置为你冀望的值。

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理