MongoDB 数据类型
MongoDB 数据类型
| 数据类型 | 中文名称 | Number | 英文名称 | 备注 |
|---|---|---|---|---|
| Double | 双精度浮点数 | 1 | “double” | |
| String | 字符串 | 2 | “string” | |
| Object | 对象 | 3 | “object” | |
| Array | 数组 | 4 | “array” | |
| Binary data | 二进制数据 | 5 | “binData” | |
| Undefined | 未定义 | 6 | “undefined” | Deprecated. |
| ObjectId | 对象编号 | 7 | “objectId” | |
| Boolean | 布尔型 | 8 | “bool” | |
| Date | 日期 | 9 | “date” | |
| Null | 空 | 10 | “null” | |
| Regular Expression | 正则表达式 | 11 | “regex” | |
| DBPointer | 12 | “dbPointer” | Deprecated. | |
| JavaScript | JS脚本 | 13 | “javascript” | |
| Symbol | 符号 | 14 | “symbol” | Deprecated. |
| JavaScript (with scope) | JS脚本(具有范围) | 15 | “javascriptWithScope” | |
| 32-bit integer | 整数 | 16 | “int” | |
| Timestamp | 时间戳 | 17 | “timestamp” | |
| 64-bit integer | 长整数 | 18 | “long” | |
| Decimal128 | 小数 | 19 | “decimal” | New in version 3.4. |
| Min key | 最小Key | -1 | “minKey” | |
| Max key | 最大Key | 127 | “maxKey” |
在 MongoDB 中数字默认 double 类型
ObjectID 和 _id
-
_id:MongoDB 中存储的文档必须有一个 _id 键,确保集合中每个文档都有唯一标识(类似 MySQL 的主键)
-
ObjectID:是 _id 的默认类型(对象很小,可能是惟一的,生成速度快,而且是有序的),由 12 个字节组成,其结构如下:

-
时间戳(4个字节):标准纪元开始的时间(秒),每一秒的时间戳是不同的
-
机器(3个字节):不同主机产生的机器名的散列值是不同的
-
PID(2个字节):同一台主机上并发多个进程产生的 ObjectID 是进程号是不同的
-
递增计数器(3个字节):自动增加的计数器,确保相同进程同一秒产生的 ObjectID 也是不一样的
时间戳+机器+PID: 确保同一秒不同机器不同进程产生的 ObjectID 是唯一的
递增计数器:用来确保在同一秒内产生的 ObjectId 也不会冲突
显然系统生成的 ObjectID 已经很严谨了,但尽量采用程序创建的方式,速度、可读性、可维护性都要强于系统创建。在客户端生成体现了 MongoDB 的设计理念:能从服务器端转移到驱动程序来做的事,就尽量转移。

浙公网安备 33010602011771号