zoukankan      html  css  js  c++  java
  • MongoDB(6)- BSON 数据类型

    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 值的长度为 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
    • 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)

    后续再展开讲

  • 相关阅读:
    maven打包将依赖和配置外置的配置方式
    AngularJS零碎总结
    Python零碎总结
    win10 平台 elasticsearch 与 elasticsearch-head 的安装
    DDD中的分层架构
    读书有感--------软件的设计原则
    DDD初探
    HTTP could not register URL http://+:86/. 设置VS默认以管理员权限打开
    .net 实战 根据configuration选项生成不同的config文件
    asp.net mvc5轻松实现插件式开发
  • 原文地址:https://www.cnblogs.com/poloyy/p/14832691.html
Copyright © 2011-2022 走看看