您现在的位置是:网站首页> 编程资料编程资料
深究从MongoDB的ObjectId中获取时间信息_MongoDB_
2023-05-27
517人已围观
简介 深究从MongoDB的ObjectId中获取时间信息_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 = 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使用小结 一些常用操作分享_MongoDB_
- MongoDB使用小结:一些不常见的经验分享_MongoDB_
- mongodb 常见问题处理方法收集_MongoDB_
- mongodb在建立一个T级别的数据库时,进程挂掉的解决方法_MongoDB_
- 记一次MongoDB性能问题(从MySQL迁移到MongoDB)_MongoDB_
- Mongodb常见错误与解决方法小结(Mongodb中经常出现的错误)_MongoDB_
- CentOS 安装 Mogodb的步骤(在线&&离线两种)_MongoDB_
- mongodb添加arbiter节点的方法示例_MongoDB_
- 利用mongodb查询某坐标是否在规定多边形区域内的方法_MongoDB_
- MongoDB数据库查询性能提高40倍的经历分享_MongoDB_
