MongoDB中的bson介紹和使用實例
一、什么是bson
BSON是一種類json的一種二進制形式的存儲格式,簡稱Binary JSON,它和JSON一樣,支持內嵌的文檔對象和數組對象,但是BSON有JSON沒有的一些數據類型,如Date和BinData類型。
BSON可以做為網絡數據交換的一種存儲形式,這個有點類似于Google的Protocol Buffer,但是BSON是一種schema-less的存儲形式,它的優(yōu)點是靈活性高,但它的缺點是空間利用率不是很理想,BSON有三個特點:輕量性、可遍歷性、高效性,
{“hello":"world"} 這是一個BSON的例子,其中"hello"是key name,它一般是cstring類型,字節(jié)表示是cstring::= (byte*) "/x00" ,其中*表示零個或多個byte字節(jié),/x00表示結束符;后面的"world"是value值,它的類型一般是string,double,array,binarydata等類型。
二、bson在MongoDB中的使用
MongoDB使用了BSON這種結構來存儲數據和網絡數據交換。把這種格式轉化成一文檔這個概念(Document),因為BSON是schema-free的,所以在MongoDB中所對應的文檔也有這個特征,這里的一個Document也可以理解成關系數據庫中的一條記錄(Record),只是這里的Document的變化更豐富一些,如Document可以嵌套。
MongoDB以BSON做為其存儲結構的一種重要原因是其可遍歷性。
三、幾個BSON的例子
3.1 一個Document的BSON表示:
{
title:"MongoDB",
last_editor:"192.168.1.122",
last_modified:new Data("27/06/2011"),
body:"MongoDB introduction",
categories:["Database","NoSQL","BSON"],
revieved:false
}
這是一個簡單的BSON結構體,其中每一個element都是由key/value對組成的
3.2 一個嵌套的例子
{
name:"lemo",
age:"12",
address:{
city:"suzhou",
country:"china",
code:215000
}
scores:[
{"name":"english","grade:3.0},
{"name":"chinese","grade:2.0}
]
}
這是一種相對復雜點的例子,其中包括了地址對象和分數對象數組,這里使用了嵌套文檔對象與文檔對象數據來表示單個學生的信息,這種嵌套的文檔結構要使用關系數據庫來做是比較復雜的。
4. BSON c++ 代碼分析
MongoDB源代碼樹中包括了BSON的代碼庫,你只要包含bson.h這個頭文件就行了,其中有四個類是比較重要的:
* mongo::BSONObj,這個是BSON對象的表示
* mongo::BSONElement,這個是BSON對象中元素的表示方法
* mongo::BSONObjBuilder,這是構建BSON對象的類
* mongo::BSONObjIterator,這是用來遍歷BSON對象中每一個元素的一個迭代器
下面是創(chuàng)建一個BSON對象
BSONObjBuilder b;
b.append("name","lemo"),
b.append("age",23);
BSONObj p = b.obj();
或者
BSONObj p = BSONObjBuilder().append("name","lemo").append("age",23).obj();
或者用流的方法來
BSONObjBuilder b;
b << "name" << "lemo" << "age" << 23;
BSONObj p = b.obj();
或者用宏來創(chuàng)建一個對象
BSONObj p = BSON( "name" << "Joe" << "age" << 33 );
這里分析一下這四個類的一些代碼:
mongo::BSONObj主要是用于存儲BSON對象的,具體的存儲格式如下
<unsigned totalSize> {<byte BSONType><cstring FieldName><Data>}* EOO
-------------------- ------------- ----------------- ---- ---
totalSize: 一個總的字節(jié)長度,包含自身
BSONType: 對象類型,這里有Boolean,String,Date等類型,具體可以參考bsontypes.h這個文件
FieldName: 這里表示字段名
Data: 這里是放具體的數據,數據的存儲方式根據不同的BSONType來
* : 表示可以有多個元素組成
EOO: 這是一個結束符,一般是/x00來表示
一般來說,BSONObj的創(chuàng)建都是通過BSONObjBuilder來做的,除非你已經得到了其字節(jié)流,那可以直接生成BSONObj
mongo::BSONElement 它主要是用于存儲對象中的單個元素,存儲格式如下
<type><fieldName><value>
這個對象主要是指向BSONObj對象中具體元素的地址,它不實際存儲元素的值。
mongo::BSONObjBuilder 它主要是用于生成BSONObj,這個對象集成了StringBuilder,它主要用于存儲實際的字節(jié)點,用于替換std::stringstream,而這個StringBuilder集成了BufBuilder,這是一個可以動態(tài)增長內存緩沖區(qū),但最大容量不能超過64MB的大小,也就是說一個BSONObj最大不能超過64MB。
mongo::BSONOBjIterator 它主要是用來遍歷BSONObj對象中的每一個元素,提供了類似于stl iterator的一些接口,它還提供了一個ForEach宏來提供更方便的操作,如
if (foo) {
BSONForEach(e, obj)
doSomething(e);
}
相關文章
Mac下安裝配置mongodb并創(chuàng)建用戶的方法
最近在在學習nodejs,相比mysql,mongodb與nodejs搭配更合適,存儲數據格式也比較接近JS對象。下面這篇文章主要給大家介紹了關于在Mac下安裝配置mongodb并創(chuàng)建用戶的相關資料,需要的朋友可以參考下2018-05-05關于MongoDB索引管理-索引的創(chuàng)建、查看、刪除操作詳解
本文講述了關于MongoDB索引管理包括索引的創(chuàng)建、查看索引、刪除索引各方面的命令及使用方法2018-03-03MongoDB的$sample、aggregate和$rand實現隨機選取數據
在MongoDB中,我們可以使用內置的$sample聚合操作符來隨機生成數據,$sample可以從集合文檔中隨機選擇指定數量的文檔,但由于其查詢整個集合的性能問題,應該慎用,aggregate方法以及$rand函數的結合使用可以實現更加靈活的查詢操作,并且可以對查詢結果進行精細篩選2024-01-01centos7防火墻導致java程序訪問mongodb3.0.1時報錯的問題分析
這篇文章主要介紹了centos7防火墻導致java程序訪問mongodb3.0.1時報錯的問題分析,需要的朋友參考下2017-01-01db.serverStatus()命名執(zhí)行時報無權限問題的解決方法
這篇文章主要給大家介紹了關于db.serverStatus()命名執(zhí)行時報無權限問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-07-07MongoDB如何正確中斷正在創(chuàng)建的索引詳解
這篇文章主要給大家介紹了關于MongoDB如何正確中斷正在創(chuàng)建的索引的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-12-12