BSON是由10gen開(kāi)發(fā)的一個(gè)數(shù)據(jù)格式骂远,目前主要用于MongoDB中园匹,是MongoDB的數(shù)據(jù)存儲(chǔ)格式扎唾。BSON基于JSON格式营密,選擇JSON進(jìn)行改造的原因主要是JSON的通用性及JSON的結(jié)構(gòu)化數(shù)據(jù)的特性。
BSON主要會(huì)實(shí)現(xiàn)以下三點(diǎn)目標(biāo)優(yōu)勢(shì):
1.更快的遍歷速度
對(duì)JSON格式來(lái)說(shuō)冰蘑,太大的JSON結(jié)構(gòu)會(huì)導(dǎo)致數(shù)據(jù)遍歷非常慢和泌。在JSON中,要跳過(guò)一個(gè)文檔進(jìn)行數(shù)據(jù)讀取祠肥,需要對(duì)此文檔進(jìn)行掃描才行武氓,需要進(jìn)行麻煩的數(shù)據(jù)結(jié)構(gòu)匹配,比如括號(hào)的匹配仇箱,而B(niǎo)SON對(duì)JSON的一大改進(jìn)就是县恕,它會(huì)將JSON的每一個(gè)元素的長(zhǎng)度存在元素的頭部,這樣你只需要讀取到元素長(zhǎng)度就能直接seek到指定的點(diǎn)上進(jìn)行讀取了剂桥。
2.操作更簡(jiǎn)易
JSON數(shù)據(jù)存儲(chǔ)是無(wú)類(lèi)型的忠烛,比如你要修改基本一個(gè)值,從9到10权逗,由于從一個(gè)字符變成了兩個(gè)美尸,所以可能其后面的所有內(nèi)容都需要往后移一位才可以。而使用BSON斟薇,你可以指定這個(gè)列為數(shù)字列师坎,那么無(wú)論數(shù)字從9長(zhǎng)到10還是100,我們都只是在存儲(chǔ)數(shù)字的那一位上進(jìn)行修改堪滨,不會(huì)導(dǎo)致數(shù)據(jù)總長(zhǎng)變大胯陋。當(dāng)然,在MongoDB中,如果數(shù)字從整形增大到長(zhǎng)整型惶岭,還是會(huì)導(dǎo)致數(shù)據(jù)總長(zhǎng)變大的寿弱。
3.增加了額外的數(shù)據(jù)類(lèi)型
JSON是一個(gè)很方便的數(shù)據(jù)交換格式犯眠,但是其類(lèi)型比較有限按灶。BSON在其基礎(chǔ)上增加了“byte array”數(shù)據(jù)類(lèi)型。這使得二進(jìn)制的存儲(chǔ)不再需要先base64轉(zhuǎn)換后再存成JSON筐咧。大大減少了計(jì)算開(kāi)銷(xiāo)和數(shù)據(jù)大小鸯旁。
當(dāng)然,在有的時(shí)候量蕊,BSON相對(duì)JSON來(lái)說(shuō)也并沒(méi)有空間上的優(yōu)勢(shì)铺罢,比如對(duì){“field”:7},在JSON的存儲(chǔ)上7只使用了一個(gè)字節(jié)残炮,而如果用BSON韭赘,那就是至少4個(gè)字節(jié)(32位)