MongoDB中ObjectId获取时间

一、ObjectId组成

ObjectId 是一个12字节 BSON 类型数据,有以下格式:

  • 前4个字节表示时间戳
  • 接下来的3个字节是机器标识码
  • 紧接的两个字节由进程id组成(PID)
  • 最后三个字节是随机数。

MongoDB中存储的文档必须有一个"_id"键。这个键的值可以是任何类型的,默认是个ObjectId对象。
在一个集合里面,每个文档都有唯一的"_id"值,来确保集合里面每个文档都能被唯一标识。
MongoDB采用ObjectId,而不是其他比较常规的做法(比如自动增加的主键)的主要原因,因为在多个 服务器上同步自动增加主键值既费力还费时。

二、从ObjectId中获取时间

算法:取id的前八位,按16进制转10进制,再乘上1000

1、网页上直接获取

  • 按“F12”进入开发者模式
    或者右键找到检查进入
    在这里插入图片描述
  • 找到console控制台输出
  • 取ObjectId前8位进行转换
eg:
//ObjectId("5c1c3db7937b4f141c2301e0")
//取前8位
new Date(Number(parseInt("5c1c3db7", 16).toString() + '000'));

2、Javascript实现

function time2id(time) {
    return mongoose.Types.ObjectId((~~(+time/1000)).toString(16) + '0'.repeat(16));
}
function id2time(id) {
    return new Date(parseInt(id.toString().substring(0, 8), 16) * 1000);
}

> id2time("5b6907878e3f488d10cd2f36")
< Tue Aug 07 2018 10:44:23 GMT+0800 (中国标准时间)

3、Python实现

def id2time(object_id):
    timeStamp = int(object_id[:8], 16)
    return time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(timeStamp))

In [20]: id2time(a)
Out[20]: '2018-08-07 10:44:23'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值