转自:https://blog.csdn.net/zengxiaosen/article/details/54908248

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表示:

[c-sharp] view plain copy
  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 一个嵌套的例子

[c-sharp] view plain copy
  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. }

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

4. BSON c++ 代码分析

MongoDB源代码树中包括了BSON的代码库,你只要包含bson.h这个头文件就行了,其中有四个类是比较重要的:

[c-sharp] view plain copy
  1. * mongo::BSONObj,这个是BSON对象的表示
  2. * mongo::BSONElement,这个是BSON对象中元素的表示方法
  3. * mongo::BSONObjBuilder,这是构建BSON对象的类
  4. * mongo::BSONObjIterator,这是用来遍历BSON对象中每一个元素的一个迭代器

下面是创建一个BSON对象

[c-sharp] view plain copy
  1. BSONObjBuilder b;
  2. b.append("name","lemo"),
  3. b.append("age",23);
  4. BSONObj p = b.obj();

或者

[c-sharp] view plain copy
  1. BSONObj p = BSONObjBuilder().append("name","lemo").append("age",23).obj();

或者用流的方法来

[c-sharp] view plain copy
  1. BSONObjBuilder b;
  2. b << "name" << "lemo" << "age" << 23;
  3. BSONObj p = b.obj();

或者用宏来创建一个对象

[c-sharp] view plain copy
  1. BSONObj p = BSON( "name" << "Joe" << "age" << 33 );

这里分析一下这四个类的一些代码:

mongo::BSONObj主要是用于存储BSON对象的,具体的存储格式如下

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

一般来说,BSONObj的创建都是通过BSONObjBuilder来做的,除非你已经得到了其字节流,那可以直接生成BSONObj

mongo::BSONElement 它主要是用于存储对象中的单个元素,存储格式如下

[c-sharp] view plain copy
  1. <type><fieldName><value>

这个对象主要是指向BSONObj对象中具体元素的地址,它不实际存储元素的值。

mongo::BSONObjBuilder 它主要是用于生成BSONObj,这个对象集成了StringBuilder,它主要用于存储实际的字节点,用于替换std::stringstream,而这个StringBuilder集成了BufBuilder,这是一个可以动态增长内存缓冲区,但最大容量不能超过64MB的大小,也就是说一个BSONObj最大不能超过64MB。

mongo::BSONOBjIterator 它主要是用来遍历BSONObj对象中的每一个元素,提供了类似于stl iterator的一些接口,它还提供了一个ForEach宏来提供更方便的操作,如

[c-sharp] view plain copy
  1. if (foo) {
  2. BSONForEach(e, obj)
  3. doSomething(e);
  4. }

转载于:https://www.cnblogs.com/sharpest/p/7868876.html

MongoDB之bson的介绍相关推荐

  1. 【MongoDB】BSON的介绍及BSON与JSON的区别

    说明 公司在用MongoDB,由于使用MongoDB时其中有一个很重要的类Document,翻看源码时发现他实现了BSON,本人之前对其不了解,故而有了这篇文章. 概念 参考百科说明:BSON( Bi ...

  2. mongodb 字符串转bson_MongoDB之bson的介绍

    转自:https://blog.csdn.net/zengxiaosen/article/details/54908248 MongoDB之bson的介绍 1. 什么是bson BSON是一种类jso ...

  3. MongoDB之Hadoop驱动介绍

    http://blog.csdn.net/amuseme_lu/article/details/6584661 MongoDB之Hadoop驱动介绍 ------------------------ ...

  4. mongodb导入bson文件_Python爬虫进阶教程(七):MongoDB数据库

    MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统.具有高性能.高可用性和自动扩展性.MongoDB 将数据存储为一个文档,数据结构由键值(key=> ...

  5. MongoDB入门示例及介绍

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! 1.Mo ...

  6. MongoDB常用使用场景介绍

    本文来介绍下MongoDB常用的使用场景 文章目录 概述 概述

  7. MongoDB工具MagicMongoDBTool使用介绍(一) -- 简单MongoDB入门

    MagicMongoDBTool工具使用指南: GitHub 下载地址 MagicMongoDBTool工具是一款MongoDB的数据库管理工具,用来进行简单的数据库管理工作. MongoDB的下载和 ...

  8. MongoDB 表结构分析工具介绍 -- Variety

    今天给大家介绍一款分析MongoDB数据库表结构的软件 -- Varity.对于MongoDB这种Schema Free的数据库来说,用软件自带的查询collection中存储的数据情况很难一眼就看出 ...

  9. 【MongoDB】BSON类型

    目录 一.ObjectId 二.字符串(String) 三.时间戳(Timestamps) 四.日期(Date) BSON是一种二进制序列化格式,用于在MongoDB中存储文档和进行远程过程调用. 有 ...

最新文章

  1. FPGA之道(18)FPGA设计的编译过程
  2. (原创)Linux下一定要4字节地址对齐操作
  3. tar压缩解压命令详解
  4. PostgreSQL学习笔记9之事务隔离
  5. 什么叫中断隐指令,具体做哪三件事呢?
  6. M283-bsp包问题
  7. zabbix 3.2.3 appliance默认用户名及密码
  8. 计算机制图 教学大纲,计算机制图教学大纲.DOC
  9. vijos1041——神风堂人数
  10. 百度豆丁文档免费下载神器
  11. 如何注册微信小程序的开发账号
  12. scheduled一分钟执行一次_Spring中使用@Scheduled创建定时任务
  13. 操作系统的内核到底是什么?
  14. UML---工厂模式
  15. 移动App測试实战:顶级互联网企业软件測试和质量提升最佳实践
  16. 多个input设置全选中的两种方式
  17. 天刀登录显示连接服务器失败ipis,天刀游戏服务器ip是什么意思
  18. 【Linux】基础IO2
  19. 在linux中 系统默认,在Red Hat Linux 9中,系统默认的( )用户对整个系统拥有完全的控制权...
  20. openssl 从证书中提取公钥

热门文章

  1. 关于MVP模式的一些讨论文章
  2. 面试必备杀技:SQL查询专项训练!
  3. 基于springboot实现的仓储管理系统
  4. Spark源码阅读02-Spark核心原理之容错及HA(高可用)
  5. javascript学习笔记2
  6. 正则 去除字符串中的特殊字符
  7. 管理信息系统 课程设计
  8. CSS 解决td里面内容太多把表格弄变形的原因,设置 自动换行。
  9. 在vs2012中用C#开发Android应用Xamarin环境搭建
  10. 7万能驱动64位离线_Dism++离线安装.NET Framework 3.5教程