首页 技术 正文
技术 2022年11月21日
0 收藏 759 点赞 4,585 浏览 1966 个字

、安装MySQL

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

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

windows下C++操作MySQL数据库

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

windows下C++操作MySQL数据库

5、添加依赖项 libmysql.lib

windows下C++操作MySQL数据库

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

windows下C++操作MySQL数据库

windows下C++操作MySQL数据库

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

windows下C++操作MySQL数据库

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

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

#include <stdio.h>

#include <mysql.h>

#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<mysql_num_fields(res);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;

}

windows下C++操作MySQL数据库

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

测试通过,十分有效

windows下C++操作MySQL数据库

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,995
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,509
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,352
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,136
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,769
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,847