一、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'