深究的意思是什么|深究从MongoDB的ObjectId中获取时间信息

更新时间:2021-08-04    来源:MongoDB    手机版     字体:

【www.bbyears.com--MongoDB】

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

   代码如下 db.getCollection("fees").find({}).forEach(function(item){   var _str = item._id.toString().substr(10, 8);   var _date = newDate(Number(parseInt(_str, 16).toString() +"000"));   item.createTime = _date;   db.fees.save(item); })  

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

本文来源:http://www.bbyears.com/shujuku/133897.html

热门标签

更多>>

本类排行