MongoDB C++ Driver编译

安装方法:最新版的,官网还在测试期,不过一个很大的提升就是Driver和Server代码分开了。

1、下载
https://codeload.github.com/mongodb/mongo-cxx-driver/zip/legacy-1.0.0-rc0


2、安装
d:\mongo-cxx-driver-legacy-1.0.0-rc0>c:Python27\Scripts\scons.py install-mongoclient --cpppath=d:\boost_1_55_0 --libpath=d:\boost_1_55_0\stage\lib --32 --dbg=on


3、将install目录的include和lib拷贝到你的项目下
VS环境配置:


目录:  头文件 ..\Src\mongodb\include;
库目录  ..\Src\mongodb\lib;
lib:libmongoclient-sgd.lib;ws2_32.lib;
预处理定义:BOOST_ALL_NO_LIB;
STATIC_LIBMONGOCLIENT(也可以再程序中定义)
#include <WinSock2.h>

下面是一些其他版本。

一、关于官网稳定版本 -- mongodb-src-r2.4.12

相关工具:boost_1_49_0或者boost_1_55_0;Scons依赖Python生成,故都需要;

现在我们编译指令:

命令行:切换到源码安装目录,执行C:\Python27\Scripts\scons.py --cpppath=d:\boost_1_55_0 --libpath=d:\boost_1_55_0\stage\lib --dd --32 mongoclient

(Tip:--dd Debug带调试信息 --32 支持32位程序 生成目标是mongoclient.lib  当然有相关其他参数:可以查看官网,也可以直接看源码目录下的SConstruct中add_option函数)

生成之后,用vs打开创建一个工程:

1、包含boost相关.cpp,可以直接将D:\mongodb-src-r2.4.12\src\mongo\client\examples\simple_client_demo.vcxproj中boost筛选器中内容拷贝到你建立的项目中

原因是我当前用的是boost_1_55_0而非自带中的1_44_0,

2、项目环境配置:(将src下的东西拷到自己的项目下吧,并且将那个lib拿出来)

     [1]、头文件目录:..\Src\mongodb\src;..\src\mongodb\src\third_party\boost;

     [2]、库目录:自己放哪配哪

     [3]、加上预处理器定义:BOOST_ALL_NO_LIB,

     [4]、添加三个必备lib, Dbghelp.lib;ws2_32.lib;mongoclient.lib;

(注意我的是--dd,所以运行库配置必须是MTd,如果是release版本请重新生成--release ,多少位程序自己顶--32/--64,生成的lib将会比debug的lib大很多253M左右,相对应的运行库配置成MT)

3、如果程序出现无法解析的xxx,那基本都是缺少lib,上面包含lib全包含就行了。最后有个tss_cleanup_implemented无法解析,直接在程序段加个这个代码吧!或者你自己找到那个lib或.cpp到项目编译也行。(考虑到这个函数在boost里基本都是空实现,应该没什么大碍,故此修改的!)

namespace boost
{
void tss_cleanup_implemented(void){}
}

 

二、新版本编译

这个版本比较新的版本,支持的编译选项较官网提供稳定版本多,支持--dynamic-windows选项(就是vs种MD/MDd模式,支持DLL的),

因为我们项目需要接口使用复杂类型(Tip:如std::string等,会存在内存申请和释放不在一个模块问题!,MT模式就会直接崩溃,而MD模式会在同一个地方申请和释放,不会存在问题)

首先去看下安装过程:https://github.com/mongodb/mongo-cxx-driver/wiki/Download%20and%20Compile

编译选项:

D:\mongo-cxx-driver-legacy-1.0.0-rc0>c:\Python27\Scripts\scons.py install-mongoc
lient --cpppath=d:\boost_1_55_0 --libpath=d:\boost_1_55_0\stage\lib --dynamic-wi
ndows --32 --dbg=on


#if 1	
///< 源码版本:mongo-cxx-driver-legacy-1.0.0-rc0,使用说明
#pragma warning(disable:4996)
// Consumers of the MongoDB C++ client library must define STATIC_LIBMONGOCLIENT when including
// this header if they intend to link against the static version of the library. This is best
// handled by adding STATIC_LIBMONGOCLIENT to the list of definitions passed on each compile
// invocation.
///< 注意1:By Lenny(调用静态MongoDBClient需定义此宏进行编译,可参见#include <mongo\bson\bson.h>)
#define STATIC_LIBMONGOCLIENT 

///< 注意2:需要此宏_WINSOCK2API_
#include <WinSock2.h>	//	_WINSOCK2API_

///< 注意3:不同模式对库的选择
/**
 *	MT/MTd/MD/MDd	d-->DLL, D-->Debug
 *	s-->static,不是dll,及MT/MTd模式
 *	gd-->dbg=on 即Debug,及MT/MD模式
 */
#ifdef _DLL	
	#ifdef _DEBUG //MDd
		#pragma comment(lib, "libmongoclient-gd.lib")
	#else	//MD
		#pragma comment(lib, "libmongoclient.lib")	//
	#endif
#else 
	#ifdef _DEBUG	//MTd
		#pragma comment(lib, "libmongoclient-sgd.lib")
	#else	//MT
		#pragma comment(lib, "libmongoclient-s.lib")
	#endif
#endif
#endif


### 如何在 Visual Studio 中配置和使用 MongoDB C++ 驱动 #### 准备工作 为了能够在 Visual Studio 中成功配置并使用 MongoDB C++ 驱动,需先完成若干准备工作。确保已安装最新版本的 Visual Studio 并具备必要的开发组件[^3]。 #### 获取驱动源码与依赖项 从 GitHub 上获取 `mongo-c-driver` 的发布版,这是构建 C++ 驱动的基础[^5]。解压后按照官方文档指示操作,在命令提示符环境下执行特定指令来生成解决方案文件: ```shell cd path\to\mongo-c-driver mkdir build && cd build "C:\Program Files (x86)\CMake\bin\cmake.exe" -G "Visual Studio 14 2015 Win64" .. ``` 这一步骤完成后会在当前目录下创建名为 `mongo-c-driver.sln` 的解决方案文件,可以直接通过 Visual Studio 打开它来进行后续编译过程[^2]。 #### 设置环境变量 对于 Windows 用户来说,设置好相应的环境路径非常重要。将 `libmongoc` 和 `libbson` 库所在的 bin 文件夹加入到系统的 PATH 变量中去,以便于链接阶段能够找到所需的动态链接库(DLL)[^4]。 #### 创建新项目集成MongoDB C++ Driver 当上述步骤都顺利完成之后,就可以着手建立一个新的 C++ 控制台应用程序工程了。接着调整项目的属性页如下所示: - **C/C++ -> General -> Additional Include Directories**: 添加 `mongo-cxx-driver/include/bsoncxx/v_noabi/`, `mongo-cxx-driver/include/mongocxx/v_noabi/`. - **Linker -> General -> Additional Library Directories**: 输入 `mongo-cxx-driver/build/src/lib`. 最后记得把静态或共享库(`*.lib`)也添加进来作为附加依赖项之一,通常位于刚才指定的那个文件夹里边。 #### 测试连接数据库功能 下面是一段简单的测试代码用来验证整个流程是否无误地完成了配置: ```cpp #include <iostream> #include <mongocxx/client.hpp> #include <mongocxx/stdx.hpp> #include <mongocxx/uri.hpp> int main() { try { mongocxx::client client{mongocxx::uri{}}; std::cout << "Connected to MongoDB successfully!" << std::endl; } catch (const std::exception& e) { std::cerr << "Failed to connect: " << e.what() << '\n'; return EXIT_FAILURE; } } ``` 如果一切正常的话,则会看到控制台上打印出成功的消息;反之则可能需要回溯之前的每一步仔细排查潜在的问题所在[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值