MongoDB(6)- BSON 数据类型

2021-06-09 22:13:25 浏览数 (1)

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 的创建时间
代码语言:javascript复制
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将用当前时间戳值替换空时间戳值

代码语言:javascript复制
db.myNewCollection1.insert({test:new timestamp()})

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

Date

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

在 shell 构造一个 date
代码语言:javascript复制
var mydate1 = new Date()
在 mongo shell 中使用 ISODate() 构造函数构造一个 Date
代码语言:javascript复制
var mydate2 = ISODate() 

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

以字符串形式返回日期值
代码语言:javascript复制
mydate1.toString()
返回日期值的月份部分

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

代码语言:javascript复制
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)

后续再展开讲

0 人点赞