VS2013连接MySQL数据库

环境:VS2013,debug版本,MySQL5.7.17版本

1、安装好mysql数据库,确保服务器中有MySQL服务,可以在资源管理器中查看:


2、打开VS2013,新建一个项目,如果安装的是32位的MySQL,则不需要进行本步,如果安装的是64位的MySQL,则需要在win32控制台上新建一个64位的环境,方法是右击项目,选择属性,右上角有一个配置管理器,点击一下,会有一个活动解决方案平台,新建一个X64即可


3、然后是对MySQL中的include和lib 文件的路径加到VS中,以及其他属性的配置如下图所示:





4、测试代码:

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <WinSock2.h>
#include "mysql.h"
#include "winsock.h"
#include <iomanip>


using namespace std;


int res = 0;


MYSQL_RES *result = NULL;
MYSQL mysql;
MYSQL_ROW sql_row;
MYSQL_FIELD *fd = NULL;


char column[20][20] = { 0 };
int selectData(char * SQL, char * Msg);


int main()
{
mysql_init(&mysql);
if (!mysql_real_connect(&mysql, "localhost", "root", "zqh18362961932", "mysql", 3306, NULL, 0))
{
cout << "连接数据库时发生错误!" << endl;
}
else
{
cout << "连接数据库成功!" << endl;
/*
//设置编码格式,否则在cmd下无法显示中文;并且插入的中文也会显示乱码
mysql_query(&mysql, "SET NAMES GBK");
char *msg = NULL;
//查询数据
char select[] = "select * from user";
if (selectData(select, msg) != 0)
{
cout << msg << endl;
}
*/
}
/*
if (result != NULL)mysql_free_result(result);//释放结果资源
mysql_close(&mysql); //释放数据库
system("pause");
return(0);
*/
system("pause");
//return(0);
}
/*
int selectData(char *SQL, char * Msg)
{
res = mysql_query(&mysql, SQL);//查询
if (!res)
{
result = mysql_store_result(&mysql);//保存查询到的数据到result
if (result)
{
int i, j;
cout << "number of result:" << mysql_num_rows(result)<<endl;
//获取列名
for (i = 0; fd = mysql_fetch_field(result); i++)
{
strcpy(column[i], fd->name);
}
j = mysql_num_fields(result);
//输出列名
for (i = 0; i<j; i++)
{
cout << setw(10) << setiosflags(ios::left) << column[i];
//printf("%s\t", column[i]);
}
cout << endl;
//获取具体的数据
while (sql_row = mysql_fetch_row(result))
{
for (i = 0; i<j; i++)
{
cout << setw(10) << setiosflags(ios::left) << sql_row[i];


//printf("%s\t",sql_row[i]);
}
cout << endl;
}
}
return 0;
}
else
{
Msg = "query sqlfailed!";
}
return(1);


}
*/

测试结果如图:


代码中注释掉的部分可能有点问题,未注释掉的部分是完全正确的。如果把服务器中的MySQL服务停止的话,像这样的情况:


再运行上面的程序,就会出现:




  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值