要给C++程序连接MySQL数据库,分别需要:
这是MySQL 数据库服务,下载了它才能在自己的电脑中使用MySQL。 下载页面:Download MySQL Installer 参考教程: windows10上安装mysql(详细步骤) 安装好后,我们打开MySQL 5.7 Command Line Client(在开始菜单的快捷方式里,也可以搜索一下),然后
创建数据库
mysql> create database test;
使用数据库(这句不能加分号)
mysql> use test
查看已有的表
mysql> show tables;
创建表
mysql> create table testuser ( id INT, name CHAR(20));
这是连接MySQL的库,我们在C++中需要使用该库来连接数据库。 下载页面:Download Connector/C++
为了在我们的C++工程里方便地引用 Connector/C++库,就要配置一下项目的依赖。 Windows10系统下编写C++工程我一般用VS,其他的IDE可以参考官方文档,如Linux中用NetBeans:Building Connector/C++ Windows Applications with Microsoft Visual Studio,以下内容也是参考文档的。
配置依赖前,先将默认的Debug模式改为Release模式。如果修改了编译方式,配置自然就改变了。
C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\include
这一步是为了让我们的C++程序可以引用连接sql相关的头文件。
接着是 项目属性 => 链接器 => 输入 => 附加依赖库
同样的方法,路径是C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\lib\opt
这一步使得.lib文件可以被找到。
动态库与静态库优缺点比较 接着根据我们的需要,执行后续步骤: 如果用静态库,可能比较麻烦,因为静态库需要和编译器版本相匹配,因此需要手动编译一份,如果选择动态库可以直接跳转到3.5
在官方下载页面,系统选择Source Code,然后版本选择64位,下载windows对应的版本。
在官方下载页面,下载最新的CMake的Windows win64-x64 Installer,安装好。
timespec
已经定义了,于是在
#ifndef HAVE_STRUCT_TIMESPEC /* Windows before VS2015 */
上面加上
#define HAVE_STRUCT_TIMESPEC
就好了。将编译出来的xxx.lib
改名为mysqlcppconn-static.lib
,放到项目根目录
如果是静态库,需要:
CPPCONN_PUBLIC_FUNC=
mysqlcppconn-static.lib
,libmysql.lib
;
libmysql.lib
的目录 C:\Program Files\MySQL\MySQL Server 5.7\lib
要填在 Configuration Properties => Linker => General => Additional Library directories中。
如果是动态库,则:
mysqlcppconn.lib
C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\lib\opt
下的mysqlcppconn.dll复制到我们的windows\system32目录下或者项目根目录\x64\Release
下。我在后续编译过程中报错说fatal error C1083: Cannot open include file: boost/shared_ptr.hpp
原来是项目没有添加boost库的额外Include目录,而mysql_connection.h
中又引用了该库。因此这一步也是需要的。
下载地址:boost_1_64_0-msvc-14.1-64.exe
下载安装好后, 项目属性 =>C/C++=> 输入 => 附加包含目录 中添加C:\local\boost_1_64_0
#include <stdlib.h>
#include <iostream>
#include "mysql_connection.h"
#include <cppconn/driver.h>
#include <cppconn/exception.h>
#include <cppconn/resultset.h>
#include <cppconn/statement.h>
using namespace std;
int main()
{
cout << endl;
cout << "正在执行 'SELECT 'Hello World!' AS _message'..." << endl;
try {
sql::Driver *driver;
sql::Connection *con;
sql::Statement *stmt;
sql::ResultSet *res;
/* 创建连接 */
driver = get_driver_instance();
con = driver->connect("tcp://127.0.0.1:3306", "root", "pwd");
/* 连接 MySQL 数据库 test */
con->setSchema("test");
stmt = con->createStatement();
res = stmt->executeQuery("SELECT 'Hello World!' AS _message");
while (res->next()) {
cout << "\t... MySQL replies: ";
/* 获取某列属性值通过列名 */
cout << res->getString("_message") << endl;
cout << "\t... MySQL says it again: ";
/* 通过数字偏移量, 1 代表第一列 */
cout << res->getString(1) << endl;
}
delete res;
delete stmt;
delete con;
}
catch (sql::SQLException &e) {
cout << "# ERR: SQLException in " << __FILE__;
cout << "(" << __FUNCTION__ << ") on line " << __LINE__ << endl;
cout << "# ERR: " << e.what();
cout << " (MySQL error code: " << e.getErrorCode();
cout << ", SQLState: " << e.getSQLState() << " )" << endl;
}
cout << endl;
return EXIT_SUCCESS;
}
更多操作见官方教程:Chapter 8 Connector/C++ Tutorials