快速入门
安装
基本操作
数据模型
SQL引擎
系统架构
数据库管理
连接器
驱动
参考手册
故障排除
SAC
版本信息
使用C++ BSON 主要会接触到以下4个类:
bson::BSONObj:创建 BSONObj 对象。
bson::BSONElement:BSONObj对象由 BSONElement 对象组成,即 BSONElement 对象为 BSONObj 对象的字段或者元素,它是键值对。
bson::BSONObjBuilder:BSONObjBuilder 用来实例化 BSONObj 对象。
bson::BSONObjlterator:BSONObjlterator 用来遍历 BSONObj 对象中的元素。
命名空间 bson 中定义了这些类的类型为:
typedef bson::BSONElement be;
typedef bson::BSONObj bo;
typedef bson::BSONObjBuilder bob;
此外,还可以使用 BASE64C API 和 FROMJSON API来帮助构建C++ BSON。
以下简单介绍如何创建 CPP BSON 实例。详细内容请查阅 C++ BSON API
使用 BSONObject,BSONObjBuilder 建立对象
#include "client.hpp" using namespace bson ; BSONObj obj ; BSONObjBuilder b ; b.append("name","sam") ; b.append("age","24") ; obj = b.obj() ; 或者 obj = BSONObjBuilder().genOID().append("name","sam").append("age",24).obj() ;
另外,可以使用数据流的方法建立 BSONObj 对象。
BSONObj obj ; BSONObjBuilder b ; b << "name" << "sam" << "age" << "24" ; obj = b.obj() ;
使用宏 BSON 建立对象
C++ BSON 中定义还定义了一个 BSON 的宏,可以用它来快速地建立 BSONObj 对象。
BSONObj obj ; // int obj = BSON( "a" << 1 ) ; // float obj = BSON( "b" << 3.14159265359 ) ; // string obj = BSON( "foo" << "bar" ) ; // OID obj = BSON( GENOID ) ; // bool obj = BSON( "flag" << true << "ret" << false ) ; // object obj = BSON( "d" << BSON("e" << "hi!") ) ; // array obj = BSON( "phone" << BSON_ARRAY( "13800138123" << "13800138124" ) ) ; // others, less then, greater then, etc obj = BSON( "g" << LT << 99 ) ;
使用 fromjson 接口建立对象
此外,可以使用 fromjson.hpp 中的 fromjson() 将 json 字符串转换成 BSONObj 对象。
string s("{name:\"sam\"}") ; fromjson ( s, obj ) ; 或者 const char *r ="{ \ firstName:\"Sam\", \ lastName:\"Smith\",age:25,id:\"count\", \ address:{streetAddress: \"25 3ndStreet\", \ city:\"NewYork\",state:\"NY\",postalCode:\"10021\"}, \ phoneNumber:[{\"type\": \"home\",number:\"212555-1234\"}] \ }" ; fromjson ( r, obj ) ;