VS2019连接mysql8.0数据库的教程图文详解

所属分类: 数据库 / Mysql 阅读数: 1342
收藏 0 赞 0 分享

1.首先准备好VS2019以及mysql数据库,两者都可以去官网下载,我们直接描述连接过程。

2.连接:

第一步:打开mysql的安装目录,我本地的安装目录如下:(注意是否有include和lib文件夹)

在这里插入图片描述

第二步:打开VS2019,新建一个空工程。

第三步:右击工程名,打开属性页:

在这里插入图片描述

第四步:打开VC++目录,在包含目录中,将mysql安装文件中的include文件的路径添加到这里:

在这里插入图片描述

第五步:还是在属性页上,打开C/C++,选择常规,和上一步一样,在附加包含目录中将mysql文件中的include文件路径添加进来:

在这里插入图片描述

第六步:还是在属性页上,点开链接器选项,点击常规,将mysql安装文件夹中的lib文件路径添加到附加库目录中:

在这里插入图片描述

第七步:还是在属性页的链接器中,点击第二项输入,将libmysql.lib文件加进来,注意,这里直接把libmysql.lib这个依赖名加进去进行,不要加路径。这个文件也在mysql安装文件夹中lib目录下:

在这里插入图片描述
在这里插入图片描述

第八步:查看属性页上方的平台,选择x64,x32可能会出错。

在这里插入图片描述

第九步:把mysql安装目录里的bin\libmysql.dll复制到c:\windows\system32下:

在这里插入图片描述
在这里插入图片描述

如果不进行这一步,运行程序的时候很有可能会报找不到libmysql.dll错误。

3.编写测试代码:

首先打开mysql数据库,我用本地已有的一个数据库表来测试:

在这里插入图片描述

测试代码:

#include <stdio.h>
#include "mysql.h"
#include<iostream>
using namespace std;
void main()
{
	MYSQL mysql; //一个数据库结构体
	MYSQL_RES* res; //一个结果集结构体
	MYSQL_ROW row; //char** 二维数组,存放一条条记录
	//初始化数据库
	mysql_init(&mysql);
	//设置编码方式
	mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "gbk");
	//连接数据库
	//判断如果连接失败就把连接失败的信息显示出来,我们好进行对应修改。
	// mysql_real_connect参数:2.本地地址 3.你的mysql用户名 4.你的mysql密码 5.数据库名字 6.端口号
	if (mysql_real_connect(&mysql, "localhost", "root", "root", "luckysheep", 3306, NULL, 0) == NULL) {
		cout << (mysql_error(&mysql));
	}
	//查询数据
	mysql_query(&mysql, "SELECT * from department");
	//获取结果集
	res = mysql_store_result(&mysql);
	//显示数据
	//给ROW赋值,判断ROW是否为空,不为空就打印数据。
	while (row = mysql_fetch_row(res))
	{
		printf("%s ", row[0]);//打印ID
		printf("%s ", row[1]);//打印ID
		cout << endl;
	}
	//释放结果集
	mysql_free_result(res);
	//关闭数据库
	mysql_close(&mysql);
	//停留等待
	getchar();
}

注意修改自己mysql的用户名和密码。
输出结果:

在这里插入图片描述

记录:其实今天想给vs2010连接mysql,因为项目在vs2010进行的,想着连接数据库进行数据测试等。但是安装了一整天,一个错一个错的解决,但是到最后,还是失败了,#include <stdbool.h>显示错误。查了一圈说是C语言内置不支持布尔类型,通过引用stdbool.h头文件,让其支持布尔类型。 但VS2010不完全支持C99…stdbool.h是C99的…时间仓促,之后有时间在排查一下吧。。。。。

在这里插入图片描述

更多精彩内容其他人还在看

简单了解标准SQL的update语句三种用法

这篇文章主要介绍了简单了解标准SQL的update语句三种用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL5.7.23解压版安装教程图文详解

这篇文章主要介绍了MySQL5.7.23解压版安装教程图文详解,本文图文并茂给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

python 连接数据库mysql解压版安装配置及遇到问题

今天学习python连接数据库,就想安装一下mysql数据库,没想到小小的数据库也遇到了不少挫折,所以我就把自己的安装过程以及问题写出来分享给大家,需要的朋友可以参考下
收藏 0 赞 0 分享

为什么说MySQL单表数据不要超过500万行

在本篇文章里小编给大家整理了一篇关于为什么说MySQL单表数据不要超过500万行的相关内容,有兴趣的朋友们阅读下吧。
收藏 0 赞 0 分享

基于python的mysql复制工具详解

python-mysql-replication 是基于python实现的 MySQL复制协议工具,我们可以用它来解析binlog 获取日志的insert,update,delete等事件 ,并基于此做其他业务需求。这篇文章主要介绍了基于python的mysql复制工具,需要的朋
收藏 0 赞 0 分享

mysql语句查询用户权限过程详解

这篇文章主要介绍了mysql语句查询用户权限过程详解,授予用户的权限可能分全局层级权限、数据库层级权限、表层级别权限、列层级别权限、子程序层级权限。,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL创建数据表并建立主外键关系详解

这篇文章主要介绍了MySQL创建数据表并建立主外键关系详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL表中添加时间戳的几种方法

这篇文章主要介绍了MySQL表中添加时间戳的几种方法,有张表的数据需要用同步工具同步至其他库,需要 update_time 时间戳字段 来做增量同步,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL如何实现负载均衡功能

这篇文章主要介绍了MySQL如何实现负载均衡功能,学习过数据库的朋友们都会知道MySQL,那么如何在MySQL下实现负载均衡功能呢?本文就将为大家细致地介绍一下
收藏 0 赞 0 分享

mysql server 5.5连接不上的解决方法

这篇文章主要为大家详细介绍了mysql server 5.5连接不上的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享
查看更多