当前位置:网站首页>JSON 与 BSON 区别
JSON 与 BSON 区别
2022-07-03 16:32:00 【云闲不收】
BSON
BSON是由10gen开发的一个数据格式,目前主要用于MongoDB中,是MongoDB的数据存储格式。BSON基于JSON格式,选择JSON进行改造的原因主要是JSON的通用性及JSON的schemaless的特性。
按照定义性来说:
BSON( Binary Serialized Document Format) 是一种二进制形式的存储格式,采用了类似于 C 语言结构体的名称、对表示方法,支持内嵌的文档对象和数组对象,具有轻量性、可遍历性、高效性的特点,可以有效描述非结构化数据和结构化数据。
BSON是一种类JSON的一种二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型。
BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,但是BSON是一种schema-less的存储形式,它的优点是灵活性高,但它的缺点是空间利用率不是很理想.
总的来说:
BSON有三个特点:轻量性、可遍历性、高效性。
JSON
JSON是 JavaScript Object Notation 的首字母缩写,单词的意思是javascript对象表示法,这里说的json指的是类似于javascript对象的一种数据格式。
使用JSON的格式与解析方便的可以表示一个对象信息,json有两种格式:①对象格式:{“key1”:obj,“key2”:obj,“key3”:obj…}、②数组/集合格式:[obj,obj,obj…]。
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进一步地发展。
边栏推荐
- 为抵制 7-Zip,列出 “三宗罪” ?网友:“第3个才是重点吧?”
- 初试scikit-learn库
- Mysql 单表字段重复数据取最新一条sql语句
- Explore Cassandra's decentralized distributed architecture
- Slam learning notes - build a complete gazebo multi machine simulation slam from scratch (4)
- 疫情常态化大背景下,关于远程办公的思考|社区征文
- Golang decorator mode and its use in NSQ
- Data driving of appium framework for mobile terminal automated testing
- 于文文、胡夏等明星带你玩转派对 皮皮APP点燃你的夏日
- First knowledge of database
猜你喜欢
Mysql 单表字段重复数据取最新一条sql语句
[proteus simulation] 8 × 8LED dot matrix screen imitates elevator digital scrolling display
Netease UI automation test exploration: airtest+poco
Cocos Creator 2. X automatic packaging (build + compile)
Two sides of the evening: tell me about the bloom filter and cuckoo filter? Application scenario? I'm confused..
Détails du contrôle de la congestion TCP | 3. Espace de conception
Remote file contains actual operation
Yu Wenwen, Hu Xia and other stars take you to play with the party. Pipi app ignites your summer
一台服务器最大并发 tcp 连接数多少?65535?
Zebras are recognized as dogs, and Stanford found the reason why AI made mistakes
随机推荐
How to initialize views when loading through storyboards- How is view initialized when loaded via a storyboard?
LeetCode1491. Average value of wages after removing the minimum wage and the maximum wage
香港理工大学|数据高效的强化学习和网络流量动态的自适应最优周界控制
Le zèbre a été identifié comme un chien, et la cause de l'erreur d'AI a été trouvée par Stanford
Cocos Creator 2.x 自动打包(构建 + 编译)
What is the maximum number of concurrent TCP connections for a server? 65535?
【剑指 Offer 】64. 求1+2+…+n
word 退格键删除不了选中文本,只能按delete
Leetcode binary search tree
Slam learning notes - build a complete gazebo multi machine simulation slam from scratch (4)
探索Cassandra的去中心化分布式架构
Top k questions of interview
Mysql 将逗号隔开的属性字段数据由列转行
Advanced Mathematics (Seventh Edition) Tongji University exercises 2-1 personal solutions
[proteus simulation] 74hc595+74ls154 drive display 16x16 dot matrix
How programming apes grow rapidly
Zebras are recognized as dogs, and Stanford found the reason why AI made mistakes
NSQ source code installation and operation process
Slam learning notes - build a complete gazebo multi machine simulation slam from scratch (I)
Unity项目优化案例一