要给C++程序连接MySQL数据库,分别需要:

  • 安装MySQL Server
  • 下载MySQL Connector/C++
  • 在IDE中配置依赖
  • 然后就可以在代码中调用API,来连接以及操作数据库。

一、安装MySQL Server

这是MySQL 数据库服务,下载了它才能在自己的电脑中使用MySQL。

下载页面:Download MySQL Installer

参考教程:windows10上安装mysql(详细步骤)

安装好后,我们打开MySQL 5.7 Command Line Client(在开始菜单的快捷方式里,也可以搜索一下),然后

  1. 创建数据库
  2. mysql> create database test;
  3. 使用数据库(这句不能加分号)
  4. mysql> use test
  5. 查看已有的表
  6. mysql> show tables;
  7. 创建表
  8. 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的静态库

  1. #ifndef HAVE_STRUCT_TIMESPEC /* Windows before VS2015 */

上面加上

  1. #define HAVE_STRUCT_TIMESPEC

就好了。将编译出来的xxx.lib改名为mysqlcppconn-static.lib,放到项目根目录

3.5 添加额外的依赖

如果是静态库,需要:

  • 在 项目属性 => C/C++=>预处理器=> 预处理中输入 CPPCONN_PUBLIC_FUNC=

  • 在 项目属性 => 链接器 => 输入 => 附加依赖库 中添加 mysqlcppconn-static.liblibmysql.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++连接的例子

  1. #include <stdlib.h>
  2. #include <iostream>
  3. #include "mysql_connection.h"
  4. #include <cppconn/driver.h>
  5. #include <cppconn/exception.h>
  6. #include <cppconn/resultset.h>
  7. #include <cppconn/statement.h>
  8. using namespace std;
  9. int main()
  10. {
  11. cout << endl;
  12. cout << "正在执行 'SELECT 'Hello World!' AS _message'..." << endl;
  13. try {
  14. sql::Driver *driver;
  15. sql::Connection *con;
  16. sql::Statement *stmt;
  17. sql::ResultSet *res;
  18. /* 创建连接 */
  19. driver = get_driver_instance();
  20. con = driver->connect("tcp://127.0.0.1:3306", "root", "pwd");
  21. /* 连接 MySQL 数据库 test */
  22. con->setSchema("test");
  23. stmt = con->createStatement();
  24. res = stmt->executeQuery("SELECT 'Hello World!' AS _message");
  25. while (res->next()) {
  26. cout << "\t... MySQL replies: ";
  27. /* 获取某列属性值通过列名 */
  28. cout << res->getString("_message") << endl;
  29. cout << "\t... MySQL says it again: ";
  30. /* 通过数字偏移量, 1 代表第一列 */
  31. cout << res->getString(1) << endl;
  32. }
  33. delete res;
  34. delete stmt;
  35. delete con;
  36. }
  37. catch (sql::SQLException &e) {
  38. cout << "# ERR: SQLException in " << __FILE__;
  39. cout << "(" << __FUNCTION__ << ") on line " << __LINE__ << endl;
  40. cout << "# ERR: " << e.what();
  41. cout << " (MySQL error code: " << e.getErrorCode();
  42. cout << ", SQLState: " << e.getSQLState() << " )" << endl;
  43. }
  44. cout << endl;
  45. return EXIT_SUCCESS;
  46. }

更多操作见官方教程:Chapter 8 Connector/C++ Tutorials

【C++】VS2015/VS2017连接Mysql数据库教程的更多相关文章

  1. VS2015 +EF6 连接MYSQL数据库生成实体

      VS2015 +EF6 连接MYSQL数据库生成实体   已安装软件:VS2015                       XAMPP Control Panel(Mysql服务器)      ...

  2. VS2015如何连接mySQL数据库

    mySQL数据库           如题,今天给大家简单演示一下VS2015如何连接mySQL数据库.       首先呢,大家需要安装vs2015和mySQL这两个软件,我还安装了一个辅助软件SQ ...

  3. VS2015如何连接mySQL数据库图文

    1.新建一个工程名叫mysql,编程环境选择c#,然后选择windows窗体应用程序,新建一个窗体用于显示查询到sql数据库的数据集 2.从工具箱向form1窗体上拖一个按钮和datagridview ...

  4. jsp连接MYSQL数据库教程(文字+图)

    步骤: 1.在mysql官网下载JDBC驱动程序.网址:https://dev.mysql.com/downloads/connector/j/ 2.把里面的jar包(mysql-connector- ...

  5. VS2017连接MySQL数据库

    vs默认无法直接连接mysql,需要我们自己配置环境. 1.下载mysql-installer-community-8.0.18.0.msi 下载地址:https://dev.mysql.com/do ...

  6. vs2017连接sqlsever数据库

    vs2017连接mysql数据库操作步骤 怎样使用vs2017连接数据库 [C++]VS2015/VS2017连接Mysql数据库教程

  7. .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程

    本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...

  8. Visual Studio 2019连接MySQL数据库详细教程

    前言 如果要在 Visual Studio 2019中使用MySQL数据库,首先需要下载MySQL的驱动 Visual Studio默认只显示微软自己的SQL Server数据源,点击其它也是微软自己 ...

  9. C# | VS2019连接MySQL的三种方法以及使用MySQL数据库教程

    本文将介绍3种添加MySQL引用的方法,以及连接MySQL和使用MySQL的教程 前篇:Visual Studio 2019连接MySQL数据库详细教程 \[QAQ \] 第一种方法 下载 Mysql ...

随机推荐

  1. 抽象代数-p22商群

    G/e={g{e}|g∈G}={{g}|g∈G}=G G/G={gG|g∈G}={G}   (gG=G左乘g是G上的双射,它的逆映射是左乘g^-1)  所以 G/G  只有一个元素,所有G  就只能是 ...

  2. Python2和Python3中urllib库中urlencode的使用注意事项

    前言 在Python中,我们通常使用urllib中的urlencode方法将字典编码,用于提交数据给url等操作,但是在Python2和Python3中urllib模块中所提供的urlencode的包 ...

  3. 【问题解决方案】Dev C++ 无法调试的问题与解决

    听翁恺老师课的时候用到一个叫DevC++的编辑器. 学到调试部分的时候,老师的没问题我的报错.我?? 试一试网上查到的方法: 工具 --> 编译选项 --> 代码生成/优化 --> ...

  4. jenkins+maven+tomcat集群发布

    jenkins+Gitlab+maven+tomcat实现自动集成.打包.部署 - 李栋94 - 博客园https://www.cnblogs.com/lidong94/p/7427923.html ...

  5. 将Myeclipse项目改成Eclipse项目

    由于项目需求,需要将原来Myeclipse项目转移到Eclipse中去.搞了半天才搞出来,分享给大家,希望对大家有用. 首先导入一个从Myeclipse导出的项目 然后无法进行tomcat发布. 但是 ...

  6. PHPUnit实践一(初识)

    PHPUnit实践一(初识)     本系列教程所有的PHPUnit测试基于PHPUnit6.5.9版本,Lumen 5.5框架 前置 日常我们的普通用到的测试: 代码直接echo,debug等方法测 ...

  7. [转帖]SAP一句话入门:Human Resource

    SAP一句话入门:Human Resource http://blog.vsharing.com/MilesForce/A621279.html HR这一句话,太简单了:组织.招聘.发工资.任职.考勤 ...

  8. iframe全屏显示

    <iframe webkitallowfullscreen="" mozallowfullscreen="" allowfullscreen=" ...

  9. Python 基础知识----数据类型

    一.Number 类型(数值类型) 二.String 类型 (字符串类型) 三.List 类型 (列表类型) 是一种常用的序列类型簇,List 用中括号 [ ] 表示,不同的元素(任意类型的值)之间以 ...

  10. Python基础知识1-基础语法

    pyenv--版本管理工具(后续再补)可参见https://www.jianshu.com/p/8aaf2525fa80 冯诺依曼体系架构 编程基础 语言分类  低级语言到高级语言 高级语言 程序Pr ...