bson
bson是由10gen開(kāi)發(fā)的一個(gè)數(shù)據(jù)格式,目前主要用于mongoDB中,是mongoDB的數(shù)據(jù)存儲(chǔ)格式,bson基于json格式
bson主要會(huì)實(shí)現(xiàn)以下三點(diǎn)目標(biāo):
- 更快的遍歷速度
bson對(duì)json的一大改進(jìn)就是,它會(huì)將json的每一個(gè)元素的長(zhǎng)度放在元素的頭部,這樣你只需要讀取到元素長(zhǎng)度就能直接seek到指定的點(diǎn)上進(jìn)行讀取了。 - 操作更簡(jiǎn)易
對(duì)json來(lái)說(shuō),數(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)變大的。 - 增加了額外的數(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只使用了1個(gè)字節(jié),而如果用bson,那就是至少4個(gè)字節(jié) (32位)
綜上所述:
- 數(shù)據(jù)結(jié)構(gòu):
json是像字符串一樣存儲(chǔ)的,bson是按結(jié)構(gòu)存儲(chǔ)的(像數(shù)組 或者說(shuō)struct) - 存儲(chǔ)空間:
bson > json - 操作速度:
bson > json
(比如,遍歷查找:json需要掃字符串,而bson可以直接定位) - 修改:
json也要大動(dòng)大移,bson就不需要。