mongo数据类型笔记

MongoDBBSON一种序列化的二进制格式存储数据。在每个序列化之前的文档又支持以下列表中的数据类型,每种数据类型都有一个对应的数字字符串别名。可以用在$type操作符中用于查询文档

数据类型

TypeNumberStringNotes
Double1“double”—–
字符串2“string”—–
对象3“object”—–
数组4“array”—–
二进制数据5“binData”—–
未定义6“undefined”已过期
ObjectId7“objectId”—–
Boolean8“bool”—–
日期9“date”—–
10“null”—–
正则表达式11“regex”—–
DBPointer12“dbPointer”已过期
JavaScript(代码)13“javascript”此数据类型用于将JavaScript代码存储到文档中
符号14“symbol”已过期
JavaScript(带范围)15“javascriptWithScope”—–
32位整数16“int”—–
时间戳17“timestamp”—–
64位整数18“long”—–
Decimal12819“decimal”New in version 3.4
Min key-1“minKey”—–
Max key127“maxKey”—–

你可以使用typeof或者instanceofinstanceof/typeof 判断一个字段值的类型

以下的代码示例,都是在Mongo shell中实现的

下面介绍一下几种重要的数据类型

ObjectId

ObjectId 类似唯一主键,可以很快的去生存和排序,包含 12 bytes,含义是:

  • 前4个字节表示创建unix时间戳,格林尼治时间 UTC时间,比北京时间晚了8个小时

  • 接下来的3个字节是机器标识码

  • 紧接的两个字节由进程id组成(PID

  • 最后三个字节是随机数

MongoDB中存储的文档必须有一个_id键。这个键的值可以是任何类型的,默认是个ObjectId对象

由于ObjectId中保存了创建的时间戳,所以你不需要为你的文档保存时间戳字段,你可以通过 getTimestamp 函数来获取文档的创建时间:

> var newObject = ObjectId()
> newObject.getTimestamp()
ISODate("2017-11-25T07:21:10Z")

ObjectId 转为字符串

> newObject.str5a1919e63df83ce79df8b38f

字符串

BSON字符串都是UTF-8编码

时间戳

BSON有一个特殊的时间戳类型用于 MongoDB 内部使用,与普通的 日期 类型不相关。 时间戳值是一个64位的值。其中:

  • 前32位是一个 time_t 值(与Unix新纪元相差的秒数)

  • 后32位是在某秒中操作的一个递增的序数

单个 mongod 实例中,时间戳值通常是唯一的

在复制集中, oplog 有一个 ts 字段。这个字段中的值使用BSON时间戳表示了操作时间

BSON时间戳类型主要用于 MongoDB内部 使用 。在大多数情况下的应用开发中,你可以使用BSON日期类型

日期

表示当前距离Unix新纪元(1970年1月1日)的毫秒数.日期类型是有符号的,负数表示1970年之前的日期

> var mydate1 = new Date() //格林尼治时间> mydate1
ISODate("2017-11-25T07:38:00.833Z")
> typeof mydate1
object
> var mydate2 = ISODate() //格林尼治时间> mydate2
ISODate("2017-11-25T07:38:57.996Z")
> typeof mydate2
object

这样创建的时间是日期类型,可以使用JS中的Date类型的方法

返回一个时间类型的字符串

> var mydate1str = mydate1.toString()
> mydate1str
Sat Nov 25 2017 15:38:00 GMT+0800 (CST)
> typeof mydate1str
string

或者

> Date()
Sat Nov 25 2017 15:43:28 GMT+0800 (CST)

Boolean

此类型用于存储布尔值:true / false

点赞