bson是由10gen开发的一个数据格式,目前主要用于mongoDB中,是mongoDB的数据存储格式。bson基于json格式,选择json进行改造的缘由主要是json的通用性及json的schemaless的特性。json
bson主要会实现如下三点目标:数组
对json格式来讲,太大的json结构会致使数据遍历很是慢。在json中,要跳过一个文档进行数据读取,须要对此文档进行扫描才行,须要进行麻烦的数据结构匹配,好比括号的匹配。
而bson对json的一大改进就是,它会将json的每个元素的长度存在元素的头部,这样你只须要读取到元素长度就能直接seek到指定的点上进行读取了。数据结构
对json来讲,数据存储是无类型的,好比你要修改基本一个值,从9到10,因为从一个字符变成了两个,因此可能其后面的全部内容都须要日后移一位才能够。
而使用bson,你能够指定这个列为数字列,那么不管数字从9长到10仍是100,咱们都只是在存储数字的那一位上进行修改,不会致使数据总长变大。
固然,在mongoDB中,若是数字从整形增大到长整型,仍是会致使数据总长变大的。less
json是一个很方便的数据交换格式,可是其类型比较有限。
bson在其基础上增长了“byte array”数据类型。这使得二进制的存储再也不须要先base64转换后再存成json,大大减小了计算开销和数据大小。
固然,在有的时候,bson相对json来讲也并无空间上的优点,好比对{“field”:7},在json的存储上7只使用了一个字节,而若是用bson,那就是至少4个字节(32位)编码
目前在10gen的努力下,bson已经有了针对多种语言的编码解码包。而且都是Apache 2 license下开源的。而且还在随着mongoDB进一步地发展。.net
数据结构:
json是像字符串同样存储的,bson是按结构存储的(像数组 或者说struct)blog
存储空间
bson>json开发
操做速度
bson>json。好比,遍历查找:json须要扫字符串,而bson能够直接定位文档
修改:
json也要大动大移,bson就不须要。字符串
参考:https://blog.csdn.net/amuseme_lu/article/details/6573912