1.创建MongoDB时,如果没有赋值ID,系统会自动帮你创建一个,通常会在客户端由驱动程序完成。默认ObjectId类
源码:
2.ObjectId使用12字节的存储空间,是一个由24个十六进制数组组成的字符串。
- 0-3位,共4位,是从标准纪元开始的时间戳,取的是当前时间的getTime()方法除以1000
- 接下来的3个字节,是所在主机的唯一标识符,一般是机器主机名的散列值
- 上面的机器字节是为了确保在不同机器产生的ObjectId不冲突,而PID就是为了在同一台机器不同的mongodb进程产生了ObjectId不冲突。
- 最后的3个字节是一个自动增加的计数器,用来确保在同一秒内产生的ObjectId也不会冲突,允许256的3次方等于16777216条记录的唯一性
因此,MongoDB不使用自增主键,而是使用ObjectId。在分布式环境中,多个机器同步一个自增ID不但费时且费力,MongoDB从一开始就是设计用来做分布式数据库的,处理多个节点是一个核心要求,而ObjectId在分片环境中要容易生成的多。