要给C++程序链接MySQL数据库,分别须要:html
这是MySQL 数据库服务,下载了它才能在本身的电脑中使用MySQL。
下载页面:Download MySQL Installer
参考教程:windows10上安装mysql(详细步骤)
安装好后,咱们打开MySQL 5.7 Command Line Client(在开始菜单的快捷方式里,也能够搜索一下),而后mysql
建立数据库 mysql> create database test; 使用数据库(这句不能加分号) mysql> use test 查看已有的表 mysql> show tables; 建立表 mysql> create table testuser ( id INT, name CHAR(20));
这是链接MySQL的库,咱们在C++中须要使用该库来链接数据库。
下载页面:Download Connector/C++linux
为了在咱们的C++工程里方便地引用 Connector/C++库,就要配置一下项目的依赖。
Windows10系统下编写C++工程我通常用VS,其余的IDE能够参考官方文档,如Linux中用NetBeans:Building Connector/C++ Windows Applications with Microsoft Visual Studio,如下内容也是参考文档的。ios
配置依赖前,先将默认的Debug模式改成Release模式。若是修改了编译方式,配置天然就改变了。
sql
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文件能够被找到。windows
动态库与静态库优缺点比较
接着根据咱们的须要,执行后续步骤:
若是用静态库,可能比较麻烦,由于静态库须要和编译器版本相匹配,所以须要手动编译一份,若是选择动态库能够直接跳转到3.5app
在官方下载页面,系统选择Source Code,而后版本选择64位,下载windows对应的版本。tcp
在官方下载页面,下载最新的CMake的Windows win64-x64 Installer,安装好。ide
我遇到的问题是报错说<my_global.h>的timespec
已经定义了,因而在
#ifndef HAVE_STRUCT_TIMESPEC /* Windows before VS2015 */
上面加上
#define HAVE_STRUCT_TIMESPEC
就行了。将编译出来的xxx.lib
更名为mysqlcppconn-static.lib
,放到项目根目录
若是是静态库,须要:
在 项目属性 => C/C++=>预处理器=> 预处理中输入 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