bson目前主要用於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,大大減少了計算開銷和資料大小。
綜上所述
資料結構上json是按字串儲存,bson是按結構儲存。
儲存空間上 bson>json
操作速度上 bson>json。比如,遍歷查詢:json需要掃字串,而bson可以直接利用預先在字串前面的字串長度直接定位。
修改上json要因為字串長度的改變而大動大移,bson的話因為是按結構儲存,因此還是占用同樣的儲存空間,不需要移動。
JSON和BSON的區別
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主要會實現以下三點目標 對json格式來說,太大的json結構會導致資料遍...