首先创建一个MFC对话框程序,添加相应组件
1. MFC连接mysql数据库
将这里下载的文件放到与项目文件相同的目录
链接:http://pan.baidu.com/s/1geX5X7P 密码:jbe6
在对话框程序对应的.cpp文件头添加如下代码
#include <winsock2.h> //定义socket #include "mysql.h" //连接mysql的接口 #pragma comment(lib,"libmysql.lib")//附加依赖项
2. 登录实例

void LoginDlg::OnOK() { // TODO: Add extra validation here GetDlgItem(IDC_EDIT1)->GetWindowText(user_name); //获得输入的用户名 GetDlgItem(IDC_EDIT2)->GetWindowText(user_passwd); //获得输入的密码 const char user[]="mysql的用户名"; const char pswd[]="密码"; const char host[]="localhost"; const char table[]="要连接的数据库名"; unsigned int port = 3306; MYSQL_RES *res; MYSQL_ROW row; MYSQL mysqlCon; if(user_name.IsEmpty()||user_passwd.IsEmpty()) { MessageBox(_T("用户名或密码不能为空!"),_T("用户登录信息")); return; } mysql_init(&mysqlCon); if (!mysql_real_connect(&mysqlCon,host,user,pswd,table,port,NULL,0)) { AfxMessageBox(_T("访问数据库失败!")); } else { // mysql_query(&mysqlCon,"SET USER GBK"); 设置字符集 } CString select_sql_by_user; select_sql_by_user.Format("select user,passwd from users where user = \'%s\'",user_name); int ress=mysql_query(&mysqlCon,(char*)(LPCSTR)select_sql_by_user); if(ress==0) //检测查询成功 { res = mysql_store_result(&mysqlCon); if(mysql_num_rows(res)==0) //查询结果为空 { AfxMessageBox("用户不存在"); } else { row=mysql_fetch_row(res); if(user_passwd==row[1]) { mysql_free_result(res); MessageBox("登录成功!"); } else { AfxMessageBox("密码错误!"); } } } mysql_close(&mysqlCon); }