最近准备把空闲时间都发在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
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,而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分两步:
一:执行E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0\tools\jam\build_dist.bat
一:执行E:\lenkydatasource\mongodb\1.2.1\boost_1_35_0\boost_1_35_0\tools\jam\build_dist.bat
二:将第一步生成的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
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
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。
选为多线程(/MT),即是静态的,不要用DLL。
编译执行,结果:
time:10.797s
insert finished
time:0.453s
query finished
time:0.094s
remove finished
time:10.797s
insert finished
time:0.453s
query finished
time:0.094s
remove finished
这个过程我遇到很多问题,一一解决后,正确流程就是上面这样,也不知道遗漏了什么没叙述没有。
first.cpp文件内容:
// first.cpp
// first.cpp
#include <iostream>
#include "client/dbclient.h"
#pragma comment(lib, "mongoclient.lib")
#pragma comment(lib, "wsock32.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;
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;
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<mongo::DBClientCursor> 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;
start = clock();
{
mongo::BSONObjBuilder query;
//query.append("user" , 1);
auto_ptr<mongo::DBClientCursor> 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;
}
cin >> errmsg;
return 0;
}