zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

深究从MongoDB的ObjectId中获取时间信息

MongoDB 获取 时间 信息 深究 ObjectId
2023-06-13 09:19:48 时间

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 = 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中获取时间信息,大家如有疑问可以留言,或者联系站长。感谢亲们支持!!!


我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题

本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 深究从MongoDB的ObjectId中获取时间信息