设为首页 收藏本站
查看: 4986|回复: 0

[经验分享] 【C++】VS2015/VS2017连接Mysql数据库教程

[复制链接]

尚未签到

发表于 2017-12-11 23:20:47 | 显示全部楼层 |阅读模式
  要给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 (>
二、下载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模式。如果修改了编译方式,配置自然就改变了。
  
DSC0000.png

3.2 添加额外的Include目录


  • 在VS菜单中选择 项目属性 =>C/C++=> 输入 => 附加包含目录
DSC0001.png



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

  这一步是为了让我们的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的静态库


  •   参考Visual Studio 2015编译64位MySQL Connector/C++

  •   我遇到的问题是报错说的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
DSC0003.png



  • 把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 &quot;mysql_connection.h&quot;
  

  
#include <cppconn/driver.h>
  
#include <cppconn/exception.h>
  
#include <cppconn/resultset.h>
  
#include <cppconn/statement.h>
  

  
using namespace std;
  

  
int main()
  
{
  cout << endl;
  cout << &quot;正在执行 'SELECT 'Hello World!' AS _message'...&quot; << endl;
  

  try {
  sql::Driver *driver;
  sql::Connection *con;
  sql::Statement *stmt;
  sql::ResultSet *res;
  

  /* 创建连接 */
  driver = get_driver_instance();
  con = driver->connect(&quot;tcp://127.0.0.1:3306&quot;, &quot;root&quot;, &quot;pwd&quot;);
  /* 连接 MySQL 数据库 test  */
  con->setSchema(&quot;test&quot;);
  

  stmt = con->createStatement();
  res = stmt->executeQuery(&quot;SELECT 'Hello World!' AS _message&quot;);
  while (res->next()) {
  cout << &quot;\t... MySQL replies: &quot;;
  /* 获取某列属性值通过列名 */
  cout << res->getString(&quot;_message&quot;) << endl;
  cout << &quot;\t... MySQL says it again: &quot;;
  /* 通过数字偏移量, 1 代表第一列 */
  cout << res->getString(1) << endl;
  }
  delete res;
  delete stmt;
  delete con;
  

  }
  catch (sql::SQLException &e) {
  cout << &quot;# ERR: SQLException in &quot; << __FILE__;
  cout << &quot;(&quot; << __FUNCTION__ << &quot;) on line &quot; << __LINE__ << endl;
  cout << &quot;# ERR: &quot; << e.what();
  cout << &quot; (MySQL error code: &quot; << e.getErrorCode();
  cout << &quot;, SQLState: &quot; << e.getSQLState() << &quot; )&quot; << endl;
  }
  

  cout << endl;
  

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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-423167-1-1.html 上篇帖子: MySQL集群(一)之主从复制 下篇帖子: mysql 如何优化left join
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表