BSON的介紹及BSON與JSON的區別

2021-08-07 13:54:17 字數 1669 閱讀 3477

新公司在用mongodb,由於使用mongodb時其中有乙個很重要的類document,翻看原始碼時發現他實現了bson,本人之前對其不了解,故而有了這篇文章。

參考百科說明:bson( binary serialized document format) 是一種二進位制形式的儲存格式,採用了類似於 c 語言結構體的名稱、對表示方法,支援內嵌的文件物件和陣列物件,具有輕量性、可遍歷性、高效性的特點,可以有效描述非結構化資料和結構化資料。

bson是一種類json的一種二進位制形式的儲存格式,簡稱binary json,它和json一樣,支援內嵌的文件物件和陣列物件,但是bson有json沒有的一些資料型別,如date和bindata型別。

bson可以做為網路資料交換的一種儲存形式,這個有點類似於google的protocol buffer,但是bson是一種schema-less的儲存形式,它的優點是靈活性高,但它的缺點是空間利用率不是很理想,

bson有三個特點:輕量性、可遍歷性、高效性。

這是乙個簡單的bson結構體,其中每乙個element都是由key/value對組成的

,

scores:[,]

}

這是一種相對複雜點的例子,其中包括了位址物件和分數物件陣列,這裡使用了巢狀文件物件與文件物件資料來表示單個學生的資訊,這種巢狀的文件結構要使用關聯式資料庫來做是比較複雜的。

以下內容參考自 

感謝謝原作者。

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來說也並沒有空間上的優勢,比如對,在json的儲存上7只使用了乙個位元組,而如果用bson,那就是至少4個位元組(32位)

目前在10gen的努力下,bson已經有了針對多種語言的編碼解碼包。並且都是apache 2 license下開源的。並且還在隨著mongodb進一步地發展。

BSON與JSON的區別

bson是由10gen開發的乙個資料格式,目前主要用於mongodb中,是mongodb的資料儲存格式。bson基於json格式,選擇json進行改造的原因主要是json的通用性及json的schemaless的特性。bson主要會實現以下三點目標 對json格式來說,太大的json結構會導致資料遍...

BSON與JSON的區別

bson是由10gen開發的乙個資料格式,目前主要用於mongodb中,是mongodb的資料儲存格式。bson基於json格式,選擇json進行改造的原因主要是json的通用性及json的schemaless的特性。bson主要會實現以下三點目標 對json格式來說,太大的json結構會導致資料遍...

BSON與JSON的區別

bson是由10gen開發的乙個資料格式,目前主要用於mongodb中,是mongodb的資料儲存格式。bson基於json格式,選擇json進行改造的原因主要是json的通用性及json的schemaless的特性。bson主要會實現以下三點目標 1.更快的遍歷速度 對json格式來說,太大的js...