一、什么是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); }
本文向大家介绍mongodb BSON的基本使用教程,包括了mongodb BSON的基本使用教程的使用技巧和注意事项,需要的朋友参考一下 查找 Find 这里查找时间戳内,账号为account,标签为tag的数据并统计个数。 聚合管道在mgo中为Pipe(pipeline interface{}) 这个和bash中使用的管道很像,数据可以被层层处理。一般传入的参数为[]bson.M。这个[]bs
问题内容: 我正在寻找一种使用GSON将MongoDB文档读入POJO的方法。直到您遇到日期和长整数之类的东西时,它才能正常工作。 我想为Gson写一个自定义适配器,它将转换任何长时间编码的BSON,我创建了自己的适配器: 我定义了以下测试来检查是否可行: 第一个(写)测试工作正常,但是读测试在以下方面失败: 因为从未调用过我的适配器的读取功能。我想这可能是因为我想映射到MyTestObject而
本文向大家介绍JSON.parse()和JSON.stringify()使用介绍,包括了JSON.parse()和JSON.stringify()使用介绍的使用技巧和注意事项,需要的朋友参考一下 parse用于从一个字符串中解析出json对象,如 结果: 注意:单引号写在{}外,每个属性名都必须用双引号,否则会抛出异常。 stringify()用于从一个对象解析出字符串,如 结果: PS:关于js
Instance类表示数据库中的一行记录,该类不能直接实例化,而应该由Model对象创建。Instance实例有两种,由Model.build方法创建的非持久化实例,和由Model.create方法创建的持久化实例。应该注意,Instance翻译后也叫做“实例”,但它在Sequelize 中是一个类,它的实例应该叫做“实例”类的实例。 实例的创建与使用 1.1 构建非持久化实例 1.2 创建持久化
本文向大家介绍MongoDB学习笔记之GridFS使用介绍,包括了MongoDB学习笔记之GridFS使用介绍的使用技巧和注意事项,需要的朋友参考一下 GridFS简介 GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。 GridFS使用 MongoDB提供了一个命令行工具mongofiles可以来处理GridFS, 列出所有文件: 上传一个文件: 下载一个文件: 查找文件:
本文向大家介绍asp中rs.BookMark的使用介绍,包括了asp中rs.BookMark的使用介绍的使用技巧和注意事项,需要的朋友参考一下 如 t=rs.BookMark 记录当前的标记 rs.BookMark=t 把游标移动到记录时的位置 例子: 当你按照这个例子自己做一遍运行的时候你就会明白了!如果还不明白(那就别写程序了...)
本文向大家介绍Vuex中的State使用介绍,包括了Vuex中的State使用介绍的使用技巧和注意事项,需要的朋友参考一下 现在在上一篇为什么要使用Vuex的介绍理解基础上使用Vuex中的State,一个正面例子来证实,同时也介绍一下Vue核心概念State。 Vuex 使用单一状态树——是的,用一个对象就包含了全部的应用层级状态。至此它便作为一个“唯一数据源 (SSOT)”而存在。这也意味着,每
本文向大家介绍PHP ignore_user_abort函数详细介绍和使用实例,包括了PHP ignore_user_abort函数详细介绍和使用实例的使用技巧和注意事项,需要的朋友参考一下 ignore_user_abort 设置与客户机断开是否会终止脚本的执行。 本函数返回 user-abort 设置的之前的值(一个布尔值)。 int ignore_user_abort ([ string $