MongoDB之bson的介绍


1. 什么是bson

BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型。

BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,但是BSON是一种schema-less的存储形式,它的优点是灵活性高,但它的缺点是空间利用率不是很理想,

BSON有三个特点:轻量性、可遍历性、高效性

{“hello":"world"} 这是一个BSON的例子,其中"hello"是key name,它一般是cstring类型,字节表示是cstring::= (byte*) "/x00" ,其中*表示零个或多个byte字节,/x00表示结束符;后面的"world"是value值,它的类型一般是string,double,array,binarydata等类型。 

2. bson在MongoDB中的使用

MongoDB使用了BSON这种结构来存储数据和网络数据交换。把这种格式转化成一文档这个概念(Document),因为BSON是schema-free的,所以在MongoDB中所对应的文档也有这个特征,这里的一个Document也可以理解成关系数据库中的一条记录(Record),只是这里的Document的变化更丰富一些,如Document可以嵌套。

MongoDB以BSON做为其存储结构的一种重要原因是其可遍历性。 

3. 几个BSON的例子

3.1 一个Document的BSON表示:

  1. {  
  2. title:"MongoDB",  
  3. last_editor:"192.168.1.122",  
  4. last_modified:new Data("27/06/2011"),  
  5. body:"MongoDB introduction",  
  6. categories:["Database","NoSQL","BSON"],  
  7. revieved:false  
  8. }  

这是一个简单的BSON结构体,其中每一个element都是由key/value对组成的

3.2 一个嵌套的例子

  1. {  
  2. name:"lemo",  
  3. age:"12",  
  4. address:{  
  5. city:"suzhou",  
  6. country:"china",  
  7. code:215000  
  8. }  
  9. scores:[  
  10. {"name":"english","grade:3.0},  
  11. {"name":"chinese","grade:2.0}  
  12. ]  
  13. }  

这是一种相对复杂点的例子,其中包括了地址对象和分数对象数组,这里使用了嵌套文档对象与文档对象数据来表示单个学生的信息,这种嵌套的文档结构要使用关系数据库来做是比较复杂的。 

  • 1
  • 2
  • 下一页

相关内容