开发者社区> night李> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

数据库操作:MFC连接与MYSQL

简介: 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);
}


这里写图片描述
能显示出来数据库中表的张数(我去,用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就是这么爽!

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
解决Ado连接MySQL使用“GetRecordCount“返回-1
解决Ado连接MySQL使用“GetRecordCount“返回-1
0 0
【大数据系列之MySQL】(二十四):MySQL中sql99语法连接操作
【大数据系列之MySQL】(二十四):MySQL中sql99语法连接操作
0 0
【大数据系列之MySQL】(二十三):MySQL中sql92语法连接操作
【大数据系列之MySQL】(二十三):MySQL中sql92语法连接操作
0 0
【大数据系列之MySQL】(九):使用Navicat连接MySQL数据库
【大数据系列之MySQL】(九):使用Navicat连接MySQL数据库
0 0
TypeScript(node)连接使用MySQL(JavaScript也一样)
node的mysql包可以帮助我们使用JavaScript来连接mysql。
0 0
Navicat连接mysql出现1251错误
Navicat连接mysql出现1251错误
0 0
Java连接MySQL数据库。编写一个应用程序,在主类Test_4类中,通过JDBC访问stu数据库,显示t_student表中的内容(表结构见表1),显示效果自己设计。
Java连接MySQL数据库。编写一个应用程序,在主类Test_4类中,通过JDBC访问stu数据库,显示t_student表中的内容(表结构见表1),显示效果自己设计。
0 0
Git:Git Bash连接MySQL
Git:Git Bash连接MySQL
0 0
Python连接MySQL数据库(简单便捷)
Python连接MySQL数据库(简单便捷)
0 0
软件开发入门教程网之​​MySQL 连接的使用
软件开发入门教程网之​​MySQL 连接的使用
0 0
+关注
night李
对机器视觉 图像处理有一定的兴趣 要做一条有梦想的咸鱼
文章
问答
文章排行榜
最热
最新
相关电子书
更多
搭建电商项目架构连接MySQL
立即下载
搭建4层电商项目架构,实战连接MySQL
立即下载
云数据库RDS MySQL从入门到高阶
立即下载