vs软件如何数据库与html连接数据库,【C++】VS2015/VS2017链接Mysql数据库教程

要给C++程序链接MySQL数据库,分别须要:html

安装MySQL Server

下载MySQL Connector/C++

在IDE中配置依赖

而后就能够在代码中调用API,来链接以及操做数据库。

1、安装MySQL Server

这是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));

2、下载MySQL Connector/C++

这是链接MySQL的库,咱们在C++中须要使用该库来链接数据库。

下载页面:Download Connector/C++linux

3、IDE中配置依赖,以Visual Studio 2015为例

为了在咱们的C++工程里方便地引用 Connector/C++库,就要配置一下项目的依赖。

Windows10系统下编写C++工程我通常用VS,其余的IDE能够参考官方文档,如Linux中用NetBeans:Building Connector/C++ Windows Applications with Microsoft Visual Studio,如下内容也是参考文档的。ios

3.1 选择编译方式

配置依赖前,先将默认的Debug模式改成Release模式。若是修改了编译方式,配置天然就改变了。

76efe05a97024e2099aec65052a52d52.pngsql

3.2 添加额外的Include目录

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

33e799e02c9df9a58ec95487d9cbbb51.png

点击

,而后选择NewLine(黄色按钮),点“...”按钮选择MySQL Connector的路径,例如个人是

C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\include

6a22c3c8d03ebb19fe6754134d2c7cf7.png

这一步是为了让咱们的C++程序能够引用链接sql相关的头文件。数据库

3.3 添加额外的库目录

接着是 项目属性 => 连接器 => 输入 => 附加依赖库

一样的方法,路径是C:\Program Files\MySQL\MySQL Connector C++ 1.1.8\lib\opt

这一步使得.lib文件能够被找到。windows

3.4 静态库和动态库:

动态库与静态库优缺点比较

接着根据咱们的须要,执行后续步骤:

若是用静态库,可能比较麻烦,由于静态库须要和编译器版本相匹配,所以须要手动编译一份,若是选择动态库能够直接跳转到3.5app

3.4.1 下载MySQL Connector/C++源码

在官方下载页面,系统选择Source Code,而后版本选择64位,下载windows对应的版本。tcp

3.4.2 下载安装CMake

在官方下载页面,下载最新的CMake的Windows win64-x64 Installer,安装好。ide

3.4.3 在vs中编译运行支持vs2017的静态库

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

50365e57729e50071898b37af87a1eef.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

4、C++链接的例子

#include

#include

#include "mysql_connection.h"

#include

#include

#include

#include

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;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值