MongoDB中的bson介绍和使用实例_MongoDB

一、什么是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等类型。
 
二、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对象中每一个元素的一个迭代器 

下面是创建一个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(); 

或者用宏来创建一个对象

复制代码 代码如下:

BSONObj p = BSON( "name" << "Joe" << "age" << 33 ); 

这里分析一下这四个类的一些代码:
mongo::BSONObj主要是用于存储BSON对象的,具体的存储格式如下

复制代码 代码如下:

 <unsigned totalSize> {<byte BSONType><cstring FieldName><Data>}* EOO 
        --------------------              -------------                -----------------               ----           --- 
totalSize: 一个总的字节长度,包含自身 
BSONType: 对象类型,这里有Boolean,String,Date等类型,具体可以参考bsontypes.h这个文件 
FieldName: 这里表示字段名 
Data: 这里是放具体的数据,数据的存储方式根据不同的BSONType来 
* : 表示可以有多个元素组成 
EOO: 这是一个结束符,一般是/x00来表示 

一般来说,BSONObj的创建都是通过BSONObjBuilder来做的,除非你已经得到了其字节流,那可以直接生成BSONObj
 
mongo::BSONElement 它主要是用于存储对象中的单个元素,存储格式如下

复制代码 代码如下:

<type><fieldName><value> 

这个对象主要是指向BSONObj对象中具体元素的地址,它不实际存储元素的值。
mongo::BSONObjBuilder 它主要是用于生成BSONObj,这个对象集成了StringBuilder,它主要用于存储实际的字节点,用于替换std::stringstream,而这个StringBuilder集成了BufBuilder,这是一个可以动态增长内存缓冲区,但最大容量不能超过64MB的大小,也就是说一个BSONObj最大不能超过64MB。
 
mongo::BSONOBjIterator 它主要是用来遍历BSONObj对象中的每一个元素,提供了类似于stl iterator的一些接口,它还提供了一个ForEach宏来提供更方便的操作,如

复制代码 代码如下:

if (foo) { 
           BSONForEach(e, obj) 
               doSomething(e); 
       } 

时间: 2024-09-13 04:18:58

MongoDB中的bson介绍和使用实例_MongoDB的相关文章

MongoDB中的bson介绍和使用实例

  这篇文章主要介绍了MongoDB中的bson介绍和使用实例,本文讲解了什么是bson.bson在MongoDB中的使用.几个BSON的例子等内容,需要的朋友可以参考下 一.什么是bson BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型. BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,

PHP库 查询Mongodb中的文档ID的方法_MongoDB

在IBM我的一份新工作是一名开发的后勤人员.那意味着我的大部分时间是在和数据库打交道.在我的工作流程中,我花了一些时间在MongoDB上面--这是一个文档数据库.但是在通过ID来检索记录这个操作上面我碰到了一些问题.下面的代码是最终版本,以后碰到类似的问题我可以直接引用它.如果大家也需要,希望下面对大家有所帮助. MongoDB 和 IDs 当我向一个集合中插入数据的时候,我并没有设置_id字段:如果这个字段是空的话,那么MongoDB将要自动生成一个ID来使用,这对我来说是非常不错的.然而,当

使用aggregate在MongoDB中查询重复数据记录的方法_MongoDB

MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). aggregate() 方法 MongoDB中聚合的方法使用aggregate(). 语法 aggregate() 方法的基本语法格式如下所示: >db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION) 我们知道,MongoDB属于文档型数据库,其存储的文档类型都是JSON对象.正是由于这一特性,我们

mongodb中使用distinct去重的简单方法_MongoDB

MongoDB的destinct命令是获取特定字段中不同值列表.该命令适用于普通字段,数组字段和数组内嵌文档. mongodb的distinct的语句: 复制代码 代码如下: db.users.distinct('last_name') 等同于 SQL 语句: 复制代码 代码如下: select DISTINCT last_name from users 表示的是根据指定的字段返回不同的记录集. 一个简单的实例: // > db.addresses.insert({"zip-code&qu

Mongodb增加、移除Shard Server实例_MongoDB

1.增加新的配置文件,并启动mongod实例 复制代码 代码如下:   #14 mkdir -p /data/mongodb/shard311 ./mongod -f /opt/mongodb-linux-x86_64-2.2.0/conf/mongod_3.conf   #16 mkdir -p /data/mongodb/shard32 ./mongod -f /opt/mongodb-linux-x86_64-2.2.0/conf/mongod_3.conf   #23 mkdir -p

MongoDB中创建索引需要注意的事项_MongoDB

上周在 ruby-china 上发了帖子<MongoDB 那些坑>,反映相当热烈,许多回复很有见地,其中一位童鞋深入的提到 MongoDB 建索引方法的问题,引发我更深入的了解了 MongoDB 建索引的方法和一些注意事项. 在 <MongoDB 那些坑>中提到,在前台直接运行建立索引命令的话,将造成整个数据库阻塞,因此索引建议使用 background 的方式建立.但是这也会带来一定的问题,在 2.6 版本之前,在 secondary server 中即使使用 backgroun

Mongodb增加、移除Arbiter节点实例_MongoDB

增加Arbiter 增加配置文件mongod1,mongod2,mongod3分别为shard1,shard2,shard3三个set集合的arbiter. 复制代码 代码如下: replSet=shard1 replSet=shard2 replSet=shard3 启动mongod实例. 连接Primary. 复制代码 代码如下: rs.addArb("192.168.1.50:10001″) rs.addArb("192.168.1.50:10002″) rs.addArb(&q

MongoDB入门教程之C#驱动操作实例_MongoDB

作为系列的最后一篇,得要说说C#驱动对mongodb的操作,目前驱动有两种:官方驱动和samus驱动,不过我个人还是喜欢后者, 因为提供了丰富的linq操作,相当方便. 官方驱动:https://github.com/mongodb/mongo-csharp-driver/downloads.下载后,还提供了一个酷似msdn的帮助文档. samus驱动:https://github.com/samus/mongodb-csharp/downloads. 下面就具体看看samus驱动,https:

MongoDB中强大的统计框架Aggregation使用实例解析_MongoDB

听说项目里面Aggregation用的多,那就专门针对这个多多练习一下. 基本的操作包括: •$project - 可以从子文档中提取字段,可以重命名字段 •$match - 可以实现查找的功能 •$limit - 接受一个数字n,返回结果集中的前n个文档. •$skip - 接受一个数字n,丢弃结果集中的前n个文档.效率比较低,依然会遍历前n个文档. •$unwind - 可以将一个包含数组的文档切分成多个, 比如你的文档有 中有个数组字段 A, A中有10个元素, 那么经过 $unwind处