意见箱
恒创运营部门将仔细参阅您的意见和建议,必要时将通过预留邮箱与您保持联络。感谢您的支持!
意见/建议
提交建议

MongoDB的objectid常见忘写时间,取当时时间的方法是什么

来源:恒创科技 编辑:恒创科技编辑部
2023-12-03 00:02:59
今天就跟大家聊聊有关“MongoDB的objectid常见忘写时间,取当时时间的方法是什么”的内容,可能很多人都不太了解,为了让大家认识和更进一步的了解,小编给大家总结了以下内容,希望这篇“MongoDB的objectid常见忘写时间,取当时时间的方法是什么”文章能对大家有帮助。

MongoDB默认使用_id字段作为主键,类型为ObjectId。ObjectId的生成有一定的规则。如果你在写入数据库的时候忘记写入创建时间,不用担心,完全可以通过_id字段的值来还原当时的时间。看下面的mongodb script脚本:

db.getCollection('fees').find({}).forEach(function(item){
  var _str = item._id.toString().substr(10, 8);
  var _date = new Date(Number(parseInt(_str, 16).toString() + '000'));
  item.createTime = _date;
  db.fees.save(item);
})

  forEach可以遍历collection中的每一条数据,然后逐一进行修改。item._id.toString()会将整个ObjectId("...")当成一个字符串来处理,然后从第10个字符开始,取8个字符,得到的是这条数据创建时的时间戳(不带毫秒位数)。在后面补上毫秒位数”000“,然后用Date()方法构造成时间对象,赋值给createTime属性。


MongoDB的objectid常见忘写时间,取当时时间的方法是什么



上述内容具有一定的借鉴价值,感兴趣的朋友可以参考,希望能对大家有帮助,想要了解更多"MongoDB的objectid常见忘写时间,取当时时间的方法是什么"的内容,大家可以关注恒创科技的其它相关文章。
上一篇: mysql直接拷贝data目录下数据库源文件还原数据库方法 下一篇: JavaScript单线程和任务队列是什么