MongoDB(6)- BSON 数据类型
阅读原文时间:2023年07月10日阅读:2

BSON

  • BSON是一种二进制序列化格式,用于在 MongoDB 中存储文档和进行远程过程调用
  • 跟 JSON 的数据结构很像,但是支持更丰富的数据类型

数据类型

数据类型

序号

别名

备注

Double

1

double

 

String

2

string

 

Object

3

object

 

Array

4

array

 

Binary data

5

binData

 

Undefined

6

undefined

弃用

ObjectId

7

objectId

 

Boolean

8

bool

 

Date

9

date

 

Null

10

null

 

Regular Expression

11

regex

 

DBPointer

12

dbPointer

弃用

JavaScript

13

javascript

 

Symbol

14

symbol

弃用

JavaScript code with scope

15

javascriptWithScope

4.4 弃用

32-bit integer

16

int

 

Timestamp

17

timestamp

 

64-bit integer

18

long

 

Decimal128

19

decimal

 

Min key

-1

minKey

 

Max key

127

maxKey  

 

序号有什么用?

到时候想通过 $type 来指定某个数据类型的时候可以用序号,而不用敲完整的字符串

可以看到,通过 $type 来指定数据类型的时候,可以用别名,也可以用序号

ObjectId

ObjectId 很小,可能是唯一的,生成速度快,并且有序,ObjectId 值的长度为 12 个字节,包括

  • 一个 4 字节的时间戳值,代表 ObjectId 的创建,以 Unix 纪元以来的秒数为单位
  • 一个 5 字节的随机值
  • 一个 3 字节递增计数器,初始化为随机值

给 _id 添加一个 ObjectId 的好处

  • 对存储 ObjectId 值的 _id 字段进行排序大致相当于按创建时间排序
  • 在 mongo shell 中,可以使用 ObjectId.getTimestamp() 方法访问 ObjectId 的创建时间

ObjectId("60b441609c297cd9d2ecf60f").getTimestamp()
ISODate("2021-05-31T01:52:32Z")

String

  • BSON 字符串是UTF-8
  • 在序列化和反序列化 BSON 时,每种编程语言的驱动程序都会从该语言的字符串格式转换为 UTF-8
  • 这使得在 BSON 字符串可以轻松存储大多数国际字
  • 此外,MongoDB $regex 查询在 regex 字符串中支持 UTF-8

Timestamps

  • BSON 有一个特殊的时间戳类型供内部 MongoDB 使用,并且与常规 Date 类型无关
  • 此内部时间戳类型是一个 64 位值
  • 前 32 位是 time_t 值(至 1970 年依赖的秒数),后 32 位是给定秒内操作的递增序数
  • 在单个 mongod 实例中,时间戳值始终是唯一的

new Timestamp()

在插入包含具有空时间戳值的顶级字段的文档时,MongoDB将用当前时间戳值替换空时间戳值

db.myNewCollection1.insert({test:new timestamp()})

db.myNewCollection1.find()
{ "_id" : ObjectId("542c2b97bac0595474108b48"), "ts" : Timestamp(1412180887, 1) }

BSON Date 是一个 64 位整数,表示自 Unix 纪元(1970 年 1 月 1 日)以来的毫秒数

在 shell 构造一个 date

var mydate1 = new Date()

在 mongo shell 中使用 ISODate() 构造函数构造一个 Date

var mydate2 = ISODate() 

两种函数构造的 Date,值是同个类型的

以字符串形式返回日期值

mydate1.toString()

返回日期值的月份部分

月是零索引,因此一月是月0

mydate1.getMonth()

不同 BSON 数据类型的比较顺序

  1. MinKey (internal type)
  2. Null
  3. Numbers (ints, longs, doubles, decimals)
  4. Symbol, String
  5. Object
  6. Array
  7. BinData
  8. ObjectId
  9. Boolean
  10. Date
  11. Timestamp
  12. Regular Expression
  13. MaxKey (internal type)

后续再展开讲