MFC编程实例之数据库操作:MFC连接与MYSQL
小职 2017-10-05 来源 :网络 阅读 1311 评论 0

摘要:本篇MFC编程实例文章将为大家讲解MFC连接与MYSQL,通过MFC编程实例的内容让你对相关知识点有进一步的认识和理解!

本篇MFC编程实例文章将为大家讲解MFC连接与MYSQL,通过MFC编程实例的内容让你对相关知识点有进一步的认识和理解!

摘要: mysql 与MFC通常情况下都是用ODBC或者是是ADO相连接,但有点伤 我直接找网上的教程,仿照着进行连接,试了n边还是只能连接上,但无法进行如图读取,写入的操作。~有点伤心。 只能去看MYSQL手册,里面有C与MYSQL的API接口;由于MFC框架中调试比较困难,所以我现在win32控制台下实现与数据库的连接与对数据库的操作。(可能这也是原因之一,我错误的以为MFC是

mysql 与MFC通常情况下都是用ODBC或者是是ADO相连接,但有点伤 我直接找网上的教程,仿照着进行连接,试了n边还是只能连接上,但无法进行如图读取,写入的操作。~有点伤心。 
只能去看MYSQL手册,里面有C与MYSQL的API接口;由于MFC框架中调试比较困难,所以我现在win32控制台下实现与数据库的连接与对数据库的操作。(可能这也是原因之一,我错误的以为MFC是程序主体,其实MFC只是界面和消息相应,有点伤~). 
首先我用的是是MYSQL5.5(建议按装32位的) 
为了方便我在MYSQL中新建一个用户,并给与其相应权限 
接下来我先进行了控制台上的编程:

#include"winsock.h"#include"mysql.h"#pragma comment(lib,"libmySQL.lib")#include "stdio.h"#include<string.h>

 

struct conn_info

{

    char *host;

    char *user;

    char *password;

    char *db;

};

MYSQL*  mysql_conn_setup(conn_info con)

{

 MYSQL *mysql = mysql_init(NULL);

 if (!mysql_real_connect(mysql,con.host,con.user,con.password,con.db,3306,NULL,0))

 {

  printf("Conection error : %s/n", mysql_error(mysql));  

        exit(1);  

 }

 return mysql;

}

MYSQL_RES* mysql_conn_sqlQuery(MYSQL *mysql,char *sql_Query)

{

    if(mysql_query(mysql,sql_Query))

    {

        printf("MySQL quer error:%s/n",mysql_error(mysql));

        exit(1);

    }

    return mysql_use_result(mysql);

}

 

void main()

{

    MYSQL *com;

    MYSQL_RES *res;

    MYSQL_ROW row;

    char sql_query[100];

    memset(sql_query,'\0',100);

    sprintf(sql_query,"show tables");

    struct conn_info info;

    info.host="localhost";

    info.user="lemon";

    info.password="123";

    info.db="student";

    com=mysql_conn_setup(info);

    res=mysql_conn_sqlQuery(com,sql_query);

    printf("mysql所有表:\n");

    int k=0;

    while((row=mysql_fetch_row(res))!=NULL)

    {

 

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

    }

    mysql_free_result(res);

    mysql_close(com);

}

 

MFC编程实例之数据库操作:MFC连接与MYSQL

能显示出来数据库中表的张数(我去,用API就是这么快);

struct conn_info

{

    char *host;

    char *user;

    char *password;

    char *db;

};

其中结构体内保存了连接数据库所需要的信息,包括用户名,接口,密码,数据库

MYSQL*  mysql_conn_setup(conn_info con)

{

 MYSQL *mysql = mysql_init(NULL);

 if (!mysql_real_connect(mysql,con.host,con.user,con.password,con.db,3306,NULL,0))

 {

  printf("Conection error : %s/n", mysql_error(mysql));  

        exit(1);  

 }

 return mysql;

}

是测试是否连接上数据库;

MYSQL_RES* mysql_conn_sqlQuery(MYSQL *mysql,char *sql_Query)

{

    if(mysql_query(mysql,sql_Query))

    {

        printf("MySQL quer error:%s/n",mysql_error(mysql));

        exit(1);

    }

    return mysql_use_result(mysql);

}

是向数据库传入你要操作的语句,sql_Query中保存的SQL语句,mysql为主程序中申明的MYSQL指针

row=mysql_fetch_row(rew)

是抓取MYSQL返回的行数 
用到mysql的部分基本上是这些,解释有点俗请见谅; 
用API就是这么爽!


希望这篇MFC编程文章可以帮助到你。总之,同学们,你想要的职坐标MFC频道都能找到!

本文由 @小职 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程