主页 > 知识库 > 数据库 > NoSQL >

mongodb c++ 起步

来源: 作者: 发表于:2012-08-20 08:41  点击:
本文是一篇转载文章,文章内容是在win下使用 C++ 在官方提供的C++客户端库的基础上操作 MongoDB 的例子,希望对广大C++程序员在使用MongoDB上能有所帮助。 原文链接: http://blog.chinaunix.net/u/26524/showart_2147440.html 最近准备把空闲时间都发在mong

本文是一篇转载文章,文章内容是在win下使用C++在官方提供的C++客户端库的基础上操作MongoDB的例子,希望对广大C++程序员在使用MongoDB上能有所帮助。

原文链接:http://blog.chinaunix.net/u/26524/showart_2147440.html

最近准备把空闲时间都发在mongodb的研究上,因此将有一系列的文章记录这个过程。

直接从官网下载了1.2.1的windows32版本:
解压之后写了个runserver.bat文件:
E:\lenkydatasource\mongodb\1.2.1\mongodb-win32-i386-1.2.1\bin\mongod.exe --dbpath E:\lenkydatasource\mongodb\1.2.1\lenkytest\db --port 55555
执行该文件即可启动mongodb服务程序。
解压文件内还包含了c++的头文件和库文件

E:\lenkydatasource\mongodb\1.2.1\mongodb-win32-i386-1.2.1\include
E:\lenkydatasource\mongodb\1.2.1\mongodb-win32-i386-1.2.1\lib
利用它们来写mongodb客户程序:
首先需要有boost,而mongodb-win32-i386-1.2.1.zip里提供的mongodb库文件

E:\lenkydatasource\mongodb\1.2.1\mongodb-win32-i386-1.2.1\lib\mongoclient.lib

此库文件是用vs2008 + boost_1_35_0编译出来的,懒得重新编译mongodb,因此也对应的使用vs2008 + boost_1_35_0编译环境即可使用这个mongoclient.lib。

boost_1_35_0从boost官网下载即可。

编译boost分两步:

  1. 执行E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0\tools\jam\build_dist.bat
  2. 将第一步生成的bjam.exe拷贝到E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0

然后执行:

cd E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0
bjam.exe link=static threading=multi variant=release runtime-link=static --without-python --toolset=msvc-9.0
完成后即会生成很多lib库,比如libboost_program_options-vc90-mt-gd-1_35.lib,把这些lib库文件(搜索lib关键字)全部拷贝到E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0\uselib目录(uselib目录是我自己建立的)
接下来利用vs2008建立工程test,包含文件first.cpp,并做下设置:
1.工具–>选项–>项目和解决方案–>VC++ 目录
加上对应的包含文件:

E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0
E:\lenkydatasource\mongodb\1.2.1\mongodb-win32-i386-1.2.1\include\mongo

加上对应的库文件:

E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0\uselib
E:\lenkydatasource\mongodb\1.2.1\mongodb-win32-i386-1.2.1\lib
2.项目–>属性(Alt+F7)–>配置属性–>C/C++–>代码生成–>运行时库
选为多线程(/MT),即是静态的,不要用DLL。
编译执行,结果:

time:10.797s
insert finished
time:0.453s
query finished
time:0.094s
remove finished
这个过程我遇到很多问题,一一解决后,正确流程就是上面这样,也不知道遗漏了什么没叙述没有。
first.cpp文件内容:
// first.cpp
#include
#include "client/dbclient.h"
#pragma comment(lib, "mongoclient.lib")
#pragma comment(lib, "wsock32.lib")
using namespace std;
int main( int argc, const char **argv ) {
int i;
clock_t start, finish;
string errmsg;
string table = "test.test";
int record = 100000;
mongo::DBClientConnection conn;
// connect db server
if (!conn.connect(string("127.0.0.1:55555"), errmsg)) {
cout << "couldn't connect to server:" << errmsg << endl;
return -1;
}

// insert test data
start = clock();
for (i = 0; i < record; i ++) {
mongo::BSONObjBuilder query;
query << "user" << i << "pwd" << i << "age" << i;
query << "email" << i << "address" << i << "phone" << i;
conn.insert(table, query.obj());
}
finish = clock();
cout << "time:" << (double)(finish - start) / CLOCKS_PER_SEC << "s" << endl;
cout << "insert finished" << endl;

// query test data
start = clock();
{
mongo::BSONObjBuilder query;
//query.append("user" , 1);
auto_ptr cursor = conn.query(table, query.obj());
while (cursor->more()) {
mongo::BSONObj obj = cursor->next();
//cout << obj.jsonString() << endl;
}
}
finish = clock();
cout << "time:" << (double)(finish - start) / CLOCKS_PER_SEC << "s" << endl;
cout << "query finished" << endl;
// remove test data
start = clock();
{
mongo::BSONObjBuilder query;
//query.append("user" , 1);
conn.remove(table, query.obj());
}
finish = clock();
cout << "time:" << (double)(finish - start) / CLOCKS_PER_SEC << "s" << endl;
cout << "remove finished" << endl; // waiting cin >> errmsg;

return 0;
}

    有帮助
    (0)
    0%
    没帮助
    (1)
    100%