mongodb 定义字段类型_MongoDB的数据类型介绍

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

数据类型:

Type

Number

String

Notes

Double

1

"double"

-----

字符串

2

"string"

-----

对象

3

"object"

-----

数组

4

"array"

-----

二进制数据

5

"binData"

-----

未定义

6

"undefined"

已过期

ObjectId

7

"objectId"

-----

Boolean

8

"bool"

-----

日期

9

"date"

-----

10

"null"

-----

正则表达式

11

"regex"

-----

DBPointer

12

"dbPointer"

已过期

JavaScript(代码)

13

"javascript"

此数据类型用于将JavaScript代码存储到文档中

符号

14

"symbol"

已过期

JavaScript(带范围)

15

"javascriptWithScope"

-----

32位整数

16

"int"

-----

时间戳

17

"timestamp"

-----

64位整数

18

"long"

-----

Decimal128

19

"decimal"

New in version 3.4

Min key

-1

"minKey"

-----

Max key

127

"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.str

5a1919e63df83ce79df8b38f

字符串

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

扫描关注,查看更多文章,提高编程能力

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值