前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >从JSON进化到BSON

从JSON进化到BSON

作者头像
Jean
发布2018-10-12 10:39:17
2.2K1
发布2018-10-12 10:39:17
举报
文章被收录于专栏:Web行业观察Web行业观察

自从MEAN引导的JSON数据格式取代传统JAVA推崇的XML以后, json的发展却停滞不前了, 当然这是好事, 因为稳定的结构是不需要向下兼容的, 但是json之所以轻便简单就是源于它的类型, 额, 确切说json就是一个字符串, 是文本, 可以存储在文件中或者数据库字段里.

要知道, 在整个宇宙都即将面向对象的年代, 数据类型(包括媒体类型)是多样化的, 而通常媒体类型和数据类型是隔离的, 以为多媒体包括什么文本啦, 图像啦, 图片, 音视频等等, 而数据类型指的是数字, 字符串, 数组, 对象, 二进制等等, 这两者是无法相通的, 比如这些数据结构是无法直接存储在文件里, 也无法直接传输在http的body中, 但有没有发现, 有一个特殊的类型是两者的唯一交集, 那即是string(文本,字符串), string是万能的, 那里都支持处理, 存储, 传输string类型. 但是现在的需求是多样化的, json这种基于string的数据结构满足不了一些高级需求, 于是乎json的扩展---bson诞生了 .

  bson是由10gen开发的一个数据格式,目前主要用于mongoDB中,是mongoDB的数据存储格式。bson基于json格式,选择json进行改造的原因主要是json的通用性及json的schemaless的特性。

  bson主要会实现以下三点目标:

1.更快的遍历速度

  对json格式来说,太大的json结构会导致数据遍历非常慢。在json中,要跳过一个文档进行数据读取,需要对此文档进行扫描才行,需要进行麻烦的数据结构匹配,比如括号的匹配。   而bson对json的一大改进就是,它会将json的每一个元素的长度存在元素的头部,这样你只需要读取到元素长度就能直接seek到指定的点上进行读取了。

2.操作更简易

  对json来说,数据存储是无类型的,比如你要修改基本一个值,从9到10,由于从一个字符变成了两个,所以可能其后面的所有内容都需要往后移一位才可以。   而使用bson,你可以指定这个列为数字列,那么无论数字从9长到10还是100,我们都只是在存储数字的那一位上进行修改,不会导致数据总长变大。   当然,在mongoDB中,如果数字从整形增大到长整型,还是会导致数据总长变大的。

3.增加了额外的数据类型

  json是一个很方便的数据交换格式,但是其类型比较有限。   bson在其基础上增加了“byte array”数据类型。这使得二进制的存储不再需要先base64转换后再存成json,大大减少了计算开销和数据大小。   当然,在有的时候,bson相对json来说也并没有空间上的优势,比如对{“field”:7},在json的存储上7只使用了一个字节,而如果用bson,那就是至少4个字节(32位)

  目前在10gen的努力下,bson已经有了针对多种语言的编码解码包。并且都是Apache 2 license下开源的。并且还在随着mongoDB进一步地发展。

总上所述:

数据结构:   json是像字符串一样存储的,bson是按结构存储的(像数组 或者说struct)

存储空间   bson>json

操作速度   bson>json。比如,遍历查找:json需要扫字符串,而bson可以直接定位

修改:   json也要大动大移,bson就不需要。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-07-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 WebHub 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.更快的遍历速度
  • 2.操作更简易
  • 3.增加了额外的数据类型
  • 总上所述:
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档