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

数据库操作:MYSQL与MFC连接(二)

简介: 继上一片博客,这篇介绍数据库与MFC的连接,上篇是介绍用控制台连接MYSQL,其实MFC为代码增加一个界面,和一些消息相应(个人认为) 首先建一个MFC的工程,我这边建了一个Dlg 建好后看一下选项-> 目录->包含目录和库目录中是否包含了MYSQL的路径 再在Dlg.cpp中添加: #include”winsock.h” #include“mys
+关注继续查看

继上一片博客,这篇介绍数据库与MFC的连接,上篇是介绍用控制台连接MYSQL,其实MFC为代码增加一个界面,和一些消息相应(个人认为)
首先建一个MFC的工程,我这边建了一个Dlg 建好后看一下选项-> 目录->包含目录和库目录中是否包含了MYSQL的路径
这里写图片描述
再在Dlg.cpp中添加:
#include”winsock.h”
#include“mysql.h”
#pragma comment(lib,”libmySQL.lib”)
这里写图片描述
然后与控制台下应用相类似:


    MYSQL mysql;
    MYSQL_RES *res;
    MYSQL_ROW row;

声明一一个结构体来保存数据库操作所需要的变量
接下来是对界面的设计:
这里写图片描述
我大致设计了:
按钮:数据库连接,查表(数据库下面有那些表),表内容(表中字段的内容),插入(将需向表中字段添加内容)
edit控件:用来显示从数据库中返回的值
大致将edit控件绑定一下的变量:
这里写图片描述
接下来设置按钮的功能函数:同样在ctrl+w下选择需要的函数相应,添加(注意都在Dlg类下添加),
在连接按钮中添加消息响应函数:

void CMy1211mfcmysql2002Dlg::Onlianmysql() 
{
    // TODO: Add your control notification handler code here
    mysql_init(&mysql);
    if(mysql_real_connect(&mysql,"localhost","ra","123","student",3306,NULL,0))
    {
        AfxMessageBox("连接成功!");
    }
    else
    {
        AfxMessageBox("连接失败");
    }
}

在查表中添加消息响应函数:

void CMy1211mfcmysql2002Dlg::Onchabiao() 
{
    // TODO: Add your control notification handler code here
    sprintf(sql_query,"show tables");
    res=mysql_conn_sqlQuery(&mysql,sql_query);
    while((row=mysql_fetch_row(res))!=NULL)
    {
        m_biaoming=m_biaoming+row[0];
        m_biaoming=m_biaoming+"\r\n";
    }
    UpdateData(false);
//  AfxMessageBox("chaxunchengg");
}

在表内容按钮中添加响应函数:

void CMy1211mfcmysql2002Dlg::Onbianneirong() 
{
    // TODO: Add your control notification handler code here
    int i=0,t;
    CString query1;
    sprintf(sql_query,"select * from student");
//  query1="SET CHARACTER SET gbk"; //设置编码
    t=mysql_real_query(&mysql,query1,(unsigned int)strlen(query1));
    res=mysql_conn_sqlQuery(&mysql,sql_query);
        while((row=mysql_fetch_row(res))!=NULL)
    {
        wodetian[i].xuehao=row[0];
        wodetian[i].xingbei=row[1];
        wodetian[i].xingming=row[2];
        wodetian[i].nianling=row[3];
        wodetian[i].xibie=row[4];
        m_neirong=m_neirong+row[0]+row[1]+row[2]+row[3]+row[4]+"\r\n";
    }
    UpdateData(false);
    AfxMessageBox("chaxunchengg");
}

注:这边设置编码是因为edit控件好像不能显示utf8的编码类型所以要将输出的编码类型变成gbk,当然好像默认的latin1编码1类型,edit控件也能输出
在插入按钮中添加消息响应函数:

void CMy1211mfcmysql2002Dlg::Oncharu() 
{
    // TODO: Add your control notification handler code here
    UpdateData(true);
    CString xuehao=m_xuehao;
    CString xingbie=m_xingbie;
    CString xingming=m_xingming;
    CString nianling=m_nianling;
    CString xibie=m_xibie;

    CString hi="insert into student(xuehao,xingbie,xingming,nianling,xibie)values('"+xuehao+"','"+xingbie+"','"+xingming+"','"+nianling+"','"+xibie+"')";
    sprintf(sql_query,hi);
    res=mysql_conn_sqlQuery(&mysql,sql_query);
    AfxMessageBox("chaxunchengg");
}

最后就能完成基本的查表插入等操作

实验结果:
这里写图片描述
显示结果如图:
然后我向student表插入全为9的一条记录;
然后用mysql的控制台查询表内的记录结果如图:
这里写图片描述
注前面两行乱码是因为我将这个数据库创建时是用默认的Latin1,后来因为需要将mysql编码方式变为了utf8,这张表的编码方式没去改变,而且提醒一下改为utf8后在控制台下显示记录会乱码,原因是控制台显示的字符编码为gbk,这时要在查表之前加上SET CHARACTER SET gbk
在mfc上更新的话主要用到了
UpdateData(true);界面到后台
UpdateData(false);后台到界面
这里写图片描述

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

相关文章
koa进行mysql数据库操作
基于数据再排序 当需要返回的信息为顺序或者倒序时,对上面的语句基于数据再排序。order by ASC/DESC 顺序或倒序 默认为顺序
0 0
C# 中的数据库操作~存储过程篇Mysql SqlServer
C# 中的数据库操作~存储过程篇Mysql SqlServer
0 0
MySQL基础教程3——DDL—数据库操作
在创建数据库时会遇到想创建的数据库名有可能已近被创建过,我们可以是使用create database if not exists 数据库名;来解决,若该数据库不存在则创建,这样即使该数据库已被创建也不会报错。
0 0
myeclipse连接MySQL数据库操作
myeclipse连接MySQL数据库操作
0 0
FastAPI数据库系列(一) MySQL数据库操作 一、简介
FastAPI中你可以使用任何关系型数据库,可以通过SQLAlchemy将其轻松的适应于任何的数据库,比如: PostgreSQL MySQL SQLite Oracle Microsoft SQL Server ...
0 0
一文了解数据库操作--mysql(25分钟)
🏆今日学习目标: 🍀学习了解数据库操作
0 0
【MySQL】—— 数据库操作基础 和 常用语法(DDL,DML,DQL,DCL)(下)
【MySQL】—— 数据库操作基础 和 常用语法(DDL,DML,DQL,DCL)(下)
0 0
【MySQL】—— 数据库操作基础 和 常用语法(DDL,DML,DQL,DCL)(上)
【MySQL】—— 数据库操作基础 和 常用语法(DDL,DML,DQL,DCL)(上)
0 0
python入门之数据库操作.mongodb和Mysql
1、目前主流的数据库有两种, * 一个是关系型数据库,如MySql * 一个是非关系型数据库 如mongodb 对与mysql和mongodb数据库,python中分别有对接的连接操作库
0 0
【MySQL】SpringBoot数据库操作乱码问题
【MySQL】SpringBoot数据库操作乱码问题
0 0
+关注
night李
对机器视觉 图像处理有一定的兴趣 要做一条有梦想的咸鱼
文章
问答
文章排行榜
最热
最新
相关电子书
更多
让 MySQL 原生分布式触手可及
立即下载
好的 MySQL 兼容可以做到什么程度
立即下载
云数据库RDS MySQL从入门到高阶
立即下载