MongoDB默认使用_id字段做为主键,类型为ObjectId。ObjectId的生成有必定的规则,详情能够查看这篇文章 - MongoDB深究之ObjectId。若是你在写入数据库的时候忘记写入建立时间,不用担忧,彻底能够经过_id字段的值来还原当时的时间。看下面的mongodb script脚本:html
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