【C++】VS2015/VS2017连接Mysql数据库教程
要给C++程序连接MySQL数据库,分别需要:
- 安装MySQL Server
- 下载MySQL Connector/C++
- 在IDE中配置依赖
- 然后就可以在代码中调用API,来连接以及操作数据库。
一、安装MySQL Server
这是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 Connector/C++
这是连接MySQL的库,我们在C++中需要使用该库来连接数据库。
下载页面:Download Connector/C++
三、IDE中配置依赖,以Visual Studio 2015为例
为了在我们的C++工程里方便地引用 Connector/C++库,就要配置一下项目的依赖。
Windows10系统下编写C++工程我一般用VS,其他的IDE可以参考官方文档,如Linux中用NetBeans:Building Connector/C++ Windows Applications with Microsoft Visual Studio,以下内容也是参考文档的。
3.1 选择编译方式
配置依赖前,先将默认的Debug模式改为Release模式。如果修改了编译方式,配置自然就改变了。

3.2 添加额外的Include目录
- 在VS菜单中选择 项目属性 =>C/C++=> 输入 => 附加包含目录

- 点击,然后选择NewLine(黄色按钮),点“...”按钮选择MySQL Connector的路径,例如我的是
C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\include

这一步是为了让我们的C++程序可以引用连接sql相关的头文件。
3.3 添加额外的库目录
接着是 项目属性 => 链接器 => 输入 => 附加依赖库
同样的方法,路径是C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\lib\opt
这一步使得.lib文件可以被找到。
3.4 静态库和动态库:
动态库与静态库优缺点比较
接着根据我们的需要,执行后续步骤:
如果用静态库,可能比较麻烦,因为静态库需要和编译器版本相匹配,因此需要手动编译一份,如果选择动态库可以直接跳转到3.5
3.4.1 下载MySQL Connector/C++源码
在官方下载页面,系统选择Source Code,然后版本选择64位,下载windows对应的版本。
3.4.2 下载安装CMake
在官方下载页面,下载最新的CMake的Windows win64-x64 Installer,安装好。
3.4.3 在vs中编译运行支持vs2017的静态库
我遇到的问题是报错说<my_global.h>的
timespec已经定义了,于是在
#ifndef HAVE_STRUCT_TIMESPEC /* Windows before VS2015 */
上面加上
#define HAVE_STRUCT_TIMESPEC
就好了。将编译出来的xxx.lib改名为mysqlcppconn-static.lib,放到项目根目录
3.5 添加额外的依赖
如果是静态库,需要:
在 项目属性 => 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下。
3.6 下载安装boost库
我在后续编译过程中报错说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
四、C++连接的例子
#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
【C++】VS2015/VS2017连接Mysql数据库教程的更多相关文章
- VS2015 +EF6 连接MYSQL数据库生成实体
VS2015 +EF6 连接MYSQL数据库生成实体 已安装软件:VS2015 XAMPP Control Panel(Mysql服务器) ...
- VS2015如何连接mySQL数据库
mySQL数据库 如题,今天给大家简单演示一下VS2015如何连接mySQL数据库. 首先呢,大家需要安装vs2015和mySQL这两个软件,我还安装了一个辅助软件SQ ...
- VS2015如何连接mySQL数据库图文
1.新建一个工程名叫mysql,编程环境选择c#,然后选择windows窗体应用程序,新建一个窗体用于显示查询到sql数据库的数据集 2.从工具箱向form1窗体上拖一个按钮和datagridview ...
- jsp连接MYSQL数据库教程(文字+图)
步骤: 1.在mysql官网下载JDBC驱动程序.网址:https://dev.mysql.com/downloads/connector/j/ 2.把里面的jar包(mysql-connector- ...
- VS2017连接MySQL数据库
vs默认无法直接连接mysql,需要我们自己配置环境. 1.下载mysql-installer-community-8.0.18.0.msi 下载地址:https://dev.mysql.com/do ...
- vs2017连接sqlsever数据库
vs2017连接mysql数据库操作步骤 怎样使用vs2017连接数据库 [C++]VS2015/VS2017连接Mysql数据库教程
- .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程
本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...
- Visual Studio 2019连接MySQL数据库详细教程
前言 如果要在 Visual Studio 2019中使用MySQL数据库,首先需要下载MySQL的驱动 Visual Studio默认只显示微软自己的SQL Server数据源,点击其它也是微软自己 ...
- C# | VS2019连接MySQL的三种方法以及使用MySQL数据库教程
本文将介绍3种添加MySQL引用的方法,以及连接MySQL和使用MySQL的教程 前篇:Visual Studio 2019连接MySQL数据库详细教程 \[QAQ \] 第一种方法 下载 Mysql ...
随机推荐
- Django 内的母版-子html规则
一.母版 在实际应用中,在开发一个网站时,从首页到主页.到目录页,等等!有时候,我们大部分基础网页头.边框.侧边框.基础css.js等复用性很高,如果每一个html都要独立去写的话,就太麻烦了. 而把 ...
- Oracle SQL优化原则
原文:http://bbs.landingbj.com/t-0-240353-1.html 1.选用适合的 ORACLE 优化器 2.访问 Table 的方式 3.共享SQL语句 共享的语句必须满足三 ...
- css太极
自己用css做的太极,留个纪念. 用css做太极有很多种实现方法,我这种大概是最简单的了吧,因为div用得太多了,哈哈. 高级一点的应该是用伪类:before和:after去减少div的用量(手动滑稽 ...
- Thread(生产者和消费者) wait、notify、notifyAll
在java中,线程间的通信可以使用wait.notify.notifyAll来进行控制.从名字就可以看出来这3个方法都是跟多线程相关的,但是可能让你感到吃惊的是:这3个方法并不是Thread类或者是R ...
- [转帖]CentOS 6 服务器安全配置指南(通用)
CentOS 6 服务器安全配置指南(通用) http://seanlook.com/2014/09/07/linux-security-general-settings/ 发表于 2014-09- ...
- Codeforces 1154F Shovels Shop
题目链接:http://codeforces.com/problemset/problem/1154/F 题目大意: 商店有n把铲子,欲购k把,现有m种优惠,每种优惠可使用多次,每种优惠(x, y)表 ...
- 老男孩 python学习自修第二十二天【文件上传与下载】
1.使用socket实现文件上传 server.py #!/usr/bin/env python # _*_ coding:UTF-8 _*_ import os import SocketServe ...
- 老男孩python学习自修第十二天【常用模块之生成随机数】
常用函数 import random random.random() 生成0到1之间的小数 random.randint(begin, end) 生成[begin, end]之间的整数 random. ...
- oracle ceil函数
ceil和floor函数在一些业务数据的时候,有时还是很有用的. ceil(n) 取大于等于数值n的最小整数: floor(n)取小于等于数值n的最大整数 如下例子 SQL> select ce ...
- 安装mysql zip5.6版--安裝
第一步当然是下载了,我下载的是压缩包形式的安装包,这种直接解压就可以了,地址是:https://dev.mysql.com/downloads/file/?id=468784 第二步就是解压了,解压到 ...