Windows程序获取mysql数据_windows下C++操作MySQL数据库

、安装MySQL

2、建立C++控制台程序,新建CPP源文件,如:sqlconn.cpp

3、工程项目中属性—C/C++--常规—附加包含目录中添加mysql安装目录中的MySQL\MySQL\MySQL Server 5.7\include

b4496eef6b716098ea4257cefef51a51.png

4、添加库目录C:\Program Files\MySQL\MySQL Server 5.7\lib

7f9bc0c261b4bb209757d733b4492ea0.png

5、添加依赖项 libmysql.lib

e6275b51a2539ec362b2a059381ad84e.png

6、运行平台改为X64(这不很重要,不然编译会报错)

4bdad1a7716e40bb155674602792dd76.png

10f7ef601fa1b836a18fc0c7d0dcb1a4.png

7、源文件中stdafx.h中添加头文件winsock.h和mysql.h(下图这样编译会报错)

e9ee5c3f9d33298fbe97ee3831aece0f.png

8、编写自己的数据库操作程序

// sqlconn.cpp : 定义控制台应用程序的入口点。

#include 

#include 

#include "stdafx.h"

int _tmain(int argc, _TCHAR* argv[])

{

MYSQL * con; //数据库对象

MYSQL_RES *res; //res结构体,用于保存查询结果

MYSQL_ROW row;

char tmp[400];

//database configuaration

char dbuser[30] = "root";

char dbpasswd[30]="root";

char dbip[30]="localhost";

char dbname[50]="test";

char tablename[50]="user";

char *query=NULL;

int x,y,rt;

unsigned int t;

int count=0;

//初始化数据库环境

con = mysql_init((MYSQL*)0);

//连接数据库

if(con!=NULL&&mysql_real_connect(con,dbip,dbuser,dbpasswd,dbname,3306,NULL,0))

{

//选择要操作的数据库

if(!mysql_select_db(con,dbname))

{

printf("select success the database!\n");

con->reconnect=1;

//执行sql语句设置编码为gbk

query="set names \'gbk\'";

rt=mysql_real_query(con,query,strlen(query));

//Sql语句执行为0则成功

if(rt){

printf("Error making query:%s!\n",mysql_error(con));

}

else{

printf("query %s success!\n",query);

}

}

}

else{

MessageBoxA(NULL,"Unable to connect the database,check your configuration!","",NULL);

}

//数据库中插入记录

//sql语句

sprintf_s(tmp,"insert into user values(null,'liujie2')");

//执行

rt = mysql_real_query(con,tmp,strlen(tmp));

if(rt){

printf("Error making query:%s!\n",mysql_error(con));

}

else{

printf("%s executed!\n",tmp);

}

//给表中插入数据

sprintf_s(tmp,"select * from %s",tablename);

//执行

rt = mysql_real_query(con,tmp,strlen(tmp));

if(rt){

printf("Error making query:%s!\n",mysql_error(con));

}

else{

printf("%s executed!\n",tmp);

}

//将查询结果保存到res结构体中

res = mysql_store_result(con);

//遍历查询结果的行

while(row = mysql_fetch_row(res)){

for(t=0;t

//打印查询行内容

printf("%s \n",row[t]);

}

printf("-----------\n");

count++;

}

printf("number of rows %d\n", count);

printf("mysql_free_result...\n");

//释放结果内存

mysql_free_result(res);

//关闭数据库连接

mysql_close(con);

system("pause");

return 0;

}

68f724bad5a33d9a9f6bd2ca7369ecb7.png

9、将编译程序和libmysql.dll放在一个目录,然后执行即可

测试通过,十分有效

f21bcae714b511d8488cfefb2fed601b.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值