最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
深究从MongoDB的ObjectId中获取时间信息
时间:2022-06-29 10:31:24 编辑:袖梨 来源:一聚教程网
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属性。
相关文章
- 以闪亮之名官网网页入口 以闪亮之名官方正版下载渠道 11-06
- 瞬间心动的温柔短句收集66句 11-06
- 燕云十六声好玩吗 燕云十六声游戏优缺点分析 11-06
- 燕云十六声最新可用的兑换码 2025年最新兑换码福利领取 11-06
- 燕云十六声云游戏入口 云燕云十六声网页版畅玩地址 11-06
- 莱莎的炼金工房3兑换码分享 终结之炼金术士与秘密钥匙DX兑换码 11-06