首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >网络编程 课设 基于C++ MFC 连接数据库 小应用 小项目浅析展示

网络编程 课设 基于C++ MFC 连接数据库 小应用 小项目浅析展示

作者头像
徐飞机
发布2018-05-15 17:23:15
1.4K0
发布2018-05-15 17:23:15
举报

  这里不知道会不会有人是真的新手 新新手 不知道怎么 如何建立一个MFC 工程 应该不会吧? 就是 打开VS 新建项目-MFC -MFC工程-点基于对话框 -和在静态库中使用 然后点击完成

注意啦 命名 都用英文 源码在这https://pan.baidu.com/s/1chRMPK

  工具:vs2013,mysql5.7.6

操作系统:win64位     注意啦 我这里是VS2013  你们要是拷贝我的工程在其他版本上可能不能用   这时候只要点击项目 - 属性-配置属性 -右边的工具集 改成你们自己的版本 就行了           

还有  我这里是 64位的   你们有可能项目是   WIN 32   的  要改     项目 -属性-右上的  配置管理器-里面的平台改成X64  不然就会出现一些 什么什么变量 在什么地方引用 之类的错误

设置一些引用文件的环境变量,基本跟opencv配置过程差不多    如果配置过OpenCV的就知道了     

点击项目->属性---改成所有配置--配置->vc++目录 然后“include目录”(包含目录)那把“C:\ProgramFiles\MySQL 5.7.6\include”给加进来  再然后“lib目录”(库目录)那里把“C:\ProgramFiles\MySQL 5.7.6\lib”和“C:\ProgramFiles\MySQL 5.7.6\lib\debug”也一起加进来。以上三个文件在mysql 的安装目录下(!!!注意啦 这是我MYSQL的安装目录  你们看自己的)    

最后在加一个 项目-属性-连接器-常规  -附加依赖项 里 加 libmysql.lib   然后在把这个MYSQL的文件 拷贝到自己MFC工程的DEBUG  或者代码放置的地方   //这里如果不加的话 就要在工程里面加上

#pragma comment (lib, "libmysql.lib")      同样还是要把文件拷贝到工程里面去     #pragma comment (lib, "mysqlclient.lib")

还有可能会因为没有加这个而报错 这个是MFC 经常的错误 #define _CRT_SECURE_NO_DEPRECATE 这个要加在stafx.h里最上面 也就是 所有头文件还没有加载的时候就要加上去

好了  下面开始进入正题:

  第一步:  除了代码给我们的 头文件  我们必要的头文件也是有要加的:

  1. #include <stdio.h>  
  2. #include <string.h>  
  3. #include <algorithm>  
  4. #include <iostream>  
  5. #include "winsock.h"  
  6. #include "mysql.h" 
  7. #include “Resource.h”

mysql.h 不能打开 就是 没有配置好   检查一下   再不行就 拷贝一份到工程里面。

第二步:

  先上代码:  这里点击我对话框BUTTON 跳转出来的函数


void CMYSQLLLINKDlg::OnBnClickedButton1()
{
    // TODO:  在此添加控件通知处理程序代码

    MYSQL m_sqlCon;
    mysql_init(&m_sqlCon);
    // localhost:服务器 root/123456为账号密码 testa为数据库名 3306为端口    
    if (!mysql_real_connect(&m_sqlCon, "localhost", "root", "123456", "testa", 3306, NULL, 0))
    {
        AfxMessageBox(_T("访问数据库失败!"));
        CString e = mysql_error(&m_sqlCon);//需要将项目属性中字符集修改为“使用多字节字符集”或“未设置”  
        MessageBox(e);
        return;
    }
    else
    {
        AfxMessageBox(_T("成功!"));
        mysql_query(&m_sqlCon, "SET NAMES 'GB2312'");//解决从数据库中读取数据后汉字乱码显示的问题  也可以是UTF-8

        CString name, id, student_name, student_id, student_major;
        //LPSTR sql = (LPSTR)malloc(200);  两种格式都可以   我喜欢用sql.Format这种
        CString sql;
        GetDlgItemText(IDC_EDIT1, name);
        GetDlgItemText(IDC_EDIT2, id);
        
        sql.Format(TEXT("select student_name,student_id,student_majo from users where father_id='%s'and father_name='%s';"), id, name);
        //sprintf(sql, "select student_name,student_id,student_majo from users where father_id='%s'and father_name='%s';", id1, name1);
        AfxMessageBox(sql);//看看SQL语句
        mysql_query(&m_sqlCon, sql);

        MYSQL_RES *res;//定义获取结果集
        MYSQL_ROW row;//获取结果集中行数据

        res = mysql_store_result(&m_sqlCon);//取得查询结果,保存查询到的数据到res   
        int num = 0;
        //这个函数每次只能获取一行数据  不过每次获取完res指针会后移  所以while循环就可以不断的获取下面的数据  不过要注意存储问题 
        if (row = mysql_fetch_row(res))
        {
            CString num1 = row[0], num2 = row[1], num3 = row[2];
            student_name = num1;
            student_id = num2;
            student_major = num3;
            SetDlgItemText(IDC_EDIT3, student_name);
            SetDlgItemText(IDC_EDIT4, student_id);
            SetDlgItemText(IDC_EDIT5, student_major);
        }
        else
        {
            CString retu(_T("输入信息有误!"));
            SetDlgItemText(IDC_EDIT3, retu);
        }
    }

    
    
}

好吧  一下上代码 可能有点乱 或者难以理解     那我们一个一个来看:

        MYSQL m_sqlCon;
	mysql_init(&m_sqlCon);        

 这个就是 建立一个MYSQL的实例对象   然后对他进行初始化      还有其他写法:

    MYSQL *sock;  
    sock=mysql_init(0);  

都是差不多的意思。

下面就是连接数据库和判断:           // localhost:服务器 root/123456为账号密码 testa为数据库名 3306为端口      &m_sqlCon这个就不用说了吧

!!!注意了整个项目  我用的都是 多字节   需要在自己项目属性那里更改    没有多字节库 的可以 去网上下载一个  安装到VS里

if (!mysql_real_connect(&m_sqlCon, "localhost", "root", "123456", "testa", 3306, NULL, 0))
	{
		AfxMessageBox(_T("访问数据库失败!"));
		CString e = mysql_error(&m_sqlCon);//需要将项目属性中字符集修改为“使用多字节字符集”或“未设置”  
		MessageBox(e);
		return;
	}
	else
	{
		AfxMessageBox(_T("成功!"));
		mysql_query(&m_sqlCon, "SET NAMES 'GB2312'");//解决从数据库中读取数据后汉字乱码显示的问题  也可以是UTF-8
        }    

好了   上面这些就是 连接数据库的 简单步骤了 。接下来我们来一个小项目玩玩。。。。。

第三步 :

上面这个就是一个简单的实现 从 MFC  到数据库的   查询学生信息的小界面。

下面 就是我数据库表格 users 放在 一个testa 的数据库里面      如果数据库安装不会的可以参照我的另外一篇安装数据库的博客http://www.cnblogs.com/DOMLX/p/8094659.html

看代码解释:

CString name, id, student_name, student_id, student_major;
        //LPSTR sql = (LPSTR)malloc(200);  两种格式都可以   我喜欢用sql.Format这种
        CString sql;
        GetDlgItemText(IDC_EDIT1, name);
        GetDlgItemText(IDC_EDIT2, id);
        
        sql.Format(TEXT("select student_name,student_id,student_majo from users where father_id='%s'and father_name='%s';"), id, name);
        //sprintf(sql, "select student_name,student_id,student_majo from users where father_id='%s'and father_name='%s';", id1, name1);
        AfxMessageBox(sql);//看看SQL语句
        mysql_query(&m_sqlCon, sql);

        MYSQL_RES *res;//定义获取结果集
        MYSQL_ROW row;//获取结果集中行数据

        res = mysql_store_result(&m_sqlCon);//取得查询结果,保存查询到的数据到res   
        int num = 0;
        //这个函数每次只能获取一行数据返回的是个行数组  不过每次获取完res指针会后移  所以while循环就可以不断的获取下面的数据  不过要注意存储问题 
        if (row = mysql_fetch_row(res))
        {
            CString num1 = row[0], num2 = row[1], num3 = row[2];//将数组中的数据存储
            student_name = num1;
            student_id = num2;
            student_major = num3;
            SetDlgItemText(IDC_EDIT3, student_name);//将数据都显示到对话框中的控件中去
            SetDlgItemText(IDC_EDIT4, student_id);
            SetDlgItemText(IDC_EDIT5, student_major);
        }
        else
        {
            CString retu(_T("输入信息有误!"));
            SetDlgItemText(IDC_EDIT3, retu);
        }

完成上面这些     加上你的数据库已经打开  并且 创建好了 表 和存入了数据 就可以开始进行查询了。

大家好我是飞机,是一个想成为全栈工程师的男人。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-01-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档