vs2013连接mysql数据库

最近接触到数据库,发现用java的jdbc连接数据库很简单,c++就很麻烦了。在网上找了很多资料,大致有两种方法:1、通过mysql的C api进行操作;2、通过mysql的Connector C++ 1.1.3进行操作。第一种方法到现在都还没有实现,不过在今天用第二种方法完成了数据库的连接。具体如下:

1、下载mysql官方的 connector API:http://dev.mysql.com/downloads/connector/cpp/ 解压或者安装
2、boost:http://netix.dl.sourceforge.net/project/boost/boost/1.60.0/boost_1_60_0.zip 解压
3、用vs新建工程,在项目属性中进行如下操作:

a、在VC++目录中的包含目录加入

vs2013连接mysql数据库_第1张图片

b、再在VC++目录的库目录中加入

vs2013连接mysql数据库_第2张图片

 c、在链接器->常规->附加库目录中加入

vs2013连接mysql数据库_第3张图片

 d、在链接器->输入->附加依赖项中加入

vs2013连接mysql数据库_第4张图片

e、在C/C++的附加包含目录中写入

vs2013连接mysql数据库_第5张图片

f、如果是64位的 将平台改成x64

g.将mysql\lib下的mysqlcppconn.dll文件和之前所输入的libmysql.dll 复制到Windows\system32 文件夹底下。


现在配置完成,用以下代码验证是否成功

#include <iostream>
#include <map>
#include <string>
#include <memory>
#include "mysql_driver.h"
#include "mysql_connection.h"
#include "cppconn/driver.h"
#include "cppconn/statement.h"
#include "cppconn/prepared_statement.h"
#include "cppconn/metadata.h"
#include "cppconn/exception.h"

using namespace std;
using namespace sql;

int main()
{
	sql::mysql::MySQL_Driver *driver = 0;
	sql::Connection *conn = 0;
	try
	{
		driver = sql::mysql::get_mysql_driver_instance();
		conn = driver->connect("tcp://localhost:3306/contest", "root", "123");//contest是自己的一个数据库,root是mysql的登录名,123是自己的密码
                                                                                      //请自行修改
		cout << "连接成功" << endl;
	}
	catch (...)
	{
		cout << "连接失败" << endl;
	}
        system("pause");
        return 0;

}




可能会出现类似这样的提示框:

vs2013连接mysql数据库_第6张图片
我在网上查了下,下面的办法有效,但不知道为什么.....


项目属性->连接器->调试->生成调试信息->是(/DEBUG)
项目属性->C/C++->常规->调试信息格式->程序数据库(/Zi)
项目属性->C/C++->优化->优化->禁用(/Od)


到此问题解决了,可以愉快的用c++操作数据库了。



你可能感兴趣的:(C++,mysql,boost,Visual,Studio)