首先創建一個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); }