mongodb Java/脚本 从ObjectId中获取日期时间信息

脚本:

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

db.getCollection('collectionName').find({}).forEach(
function(item){
    var _str = item._id.toString().substr(10, 8);
    printjson(item._id.toString() + " " + _str);
    var _date = new Date(Number(parseInt(_str, 16).toString() + '000'));
    printjson(_date);
})

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

结果:

"ObjectId(\"5c652b8fff11907db3792b1c\") 5c652b8f"
ISODate("2019-02-14T08:49:19Z")
"ObjectId(\"5c652b8fff11907db3792b1f\") 5c652b8f"
ISODate("2019-02-14T08:49:19Z")

Java:

Date date = new Date(Long.parseLong(Integer.parseInt(doc.getObjectId("_id").toString().substring(0, 8), 16).toString() + "000"))

java中id转字符串结果为:5c652b8fff11907db3792b1c,因此取前8位

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值