MFC 基于数据库的管理系统

文章目录

初始化

创建文件选择基于CListView

初始化数据

cpp 复制代码
public:
	CListCtrl& m_list;
cpp 复制代码
CSQLView::CSQLView() noexcept
	:m_list(GetListCtrl())
{
	// TODO: 在此处添加构造代码

}
cpp 复制代码
void CSQLView::OnInitialUpdate()
{
	CListView::OnInitialUpdate();

	m_list.ModifyStyle(0, LVS_REPORT);
	m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES);
	m_list.InsertColumn(0, L"id", LVCFMT_LEFT, 100);
	m_list.InsertColumn(1, L"姓名", LVCFMT_LEFT, 100);
	m_list.InsertColumn(2, L"性别", LVCFMT_LEFT, 100);
	m_list.InsertColumn(3, L"年龄", LVCFMT_LEFT, 100);
	m_list.InsertColumn(4, L"部门", LVCFMT_LEFT, 100);
	m_list.InsertColumn(5, L"岗位", LVCFMT_LEFT, 100);
	m_list.InsertColumn(6, L"薪资", LVCFMT_LEFT, 100);
//修改数据库
	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql=L"select * from user";

	
	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0, sql.GetBuffer(), sql.GetLength(), str, sizeof(str), NULL, NULL);
	int error = mysql.Query(str);
	if (error)
	{
		MessageBox(L"查询失败");
		return;
	}


	mysql.StoreResult();
	int i = 0;
	//显示有问题
	while (mysql.FetchRow())
	{
		m_list.InsertItem(i,(wchar_t*)(mysql.m_mysql_row[0]));
		m_list.InsertItem(i, (wchar_t*)(mysql.m_mysql_row[1]));
		m_list.InsertItem(i, (wchar_t*)(mysql.m_mysql_row[2]));
		m_list.InsertItem(i, (wchar_t*)(mysql.m_mysql_row[3]));
	}
}

设置菜单

添加

创建添加类
每一个控件都添加控件变量

cpp 复制代码
class CAddDlg : public CDialogEx
{
	DECLARE_DYNAMIC(CAddDlg)

public:
	CAddDlg(CWnd* pParent = nullptr);   // 标准构造函数
	virtual ~CAddDlg();

// 对话框数据
#ifdef AFX_DESIGN_TIME
	enum { IDD = IDD_ADD_DLG };
#endif

protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

	DECLARE_MESSAGE_MAP()
public:
	CString m_strName;
	CString m_strSex;
	int m_nAge;
	CString m_strDeparment;
	CString m_strJob;
	float m_fSalary;
	afx_msg void OnBnClickedAdd();
	
};

// CAddDlg.cpp: 实现文件

cpp 复制代码
//

#include "pch.h"
#include "SQL.h"
#include "CAddDlg.h"
#include "afxdialogex.h"


// CAddDlg 对话框

IMPLEMENT_DYNAMIC(CAddDlg, CDialogEx)

CAddDlg::CAddDlg(CWnd* pParent /*=nullptr*/)
	: CDialogEx(IDD_ADD_DLG, pParent)
	, m_strName(_T(""))
	, m_strSex(_T(""))
	, m_nAge(0)
	, m_strDeparment(_T(""))
	, m_strJob(_T(""))
	, m_fSalary(0)
{

}

CAddDlg::~CAddDlg()
{
}

void CAddDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
	DDX_Text(pDX, IDC_EDIT2, m_strName);
	DDX_Text(pDX, IDC_EDIT1, m_strSex);
	DDX_Text(pDX, IDC_EDIT3, m_nAge);
	DDX_Text(pDX, IDC_EDIT4, m_strDeparment);
	DDX_Text(pDX, IDC_EDIT5, m_strJob);
	DDX_Text(pDX, IDC_EDIT6, m_fSalary);
}


BEGIN_MESSAGE_MAP(CAddDlg, CDialogEx)
	ON_BN_CLICKED(IDC_ADD, &CAddDlg::OnBnClickedAdd)
	
END_MESSAGE_MAP()


// CAddDlg 消息处理程序


void CAddDlg::OnBnClickedAdd()
{
	UpdateData();
	EndDialog(IDOK);
}
cpp 复制代码
//添加
void CSQLView::OnAdd()
{
	CAddDlg dlg;
	if (IDCANCEL == dlg.DoModal())
		return;
	
	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql;
	sql.Format(L"insert into user(name,sex,age,department,job,salary) value (\'%s\',\'%s\',%d,\'%s\',\'%s\',%f);",
		dlg.m_strName,dlg.m_strSex,dlg.m_nAge,dlg.m_strDeparment,dlg.m_strJob,dlg.m_fSalary);

	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0,sql.GetBuffer(),sql.GetLength(),str,sizeof(str),NULL,NULL);
	int error=mysql.Query(str);
	if(error)
	{
		MessageBox(L"添加失败");
		return;
	}
	MessageBox(L"添加成功");
	//插入到列表
	int nCount = m_list.GetItemCount();
	CString str1;
	str1.Format(L"%d", nCount);
	m_list.InsertItem(nCount, str1);
	m_list.SetItemText(nCount, 1, dlg.m_strName);
	m_list.SetItemText(nCount, 2, dlg.m_strSex);
	str1.Format(L"%d", dlg.m_nAge);
	m_list.SetItemText(nCount, 3, str1);
	m_list.SetItemText(nCount, 4, dlg.m_strDeparment);
	m_list.SetItemText(nCount, 5, dlg.m_strJob);
	str1.Format(L"%.2f", dlg.m_fSalary);
	m_list.SetItemText(nCount, 6, str1);

}

删除

cpp 复制代码
//删除
void CSQLView::OnDelete()
{
	POSITION pos=m_list.GetFirstSelectedItemPosition();
	int nSel = m_list.GetNextSelectedItem(pos);
	if (nSel<0)
	{
		MessageBox(L"先选中在删除");
		return;
	}

	CString strDelete = m_list.GetItemText(nSel, 1);

	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql;
	sql.Format(L"delete from user where name=\'%s\';", strDelete);

	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0, sql.GetBuffer(), sql.GetLength(), str, sizeof(str), NULL, NULL);
	int error = mysql.Query(str);
	if (error)
	{
		MessageBox(L"删除失败");
		return;
	}
	m_list.DeleteItem(nSel);
}

修改

设置添加对话框
添加修改类
// CModifyDlg 对话框

cpp 复制代码
class CModifyDlg : public CDialogEx
{
	DECLARE_DYNAMIC(CModifyDlg)

public:
	CModifyDlg(CWnd* pParent = nullptr);   // 标准构造函数
	virtual ~CModifyDlg();

// 对话框数据
#ifdef AFX_DESIGN_TIME
	enum { IDD = IDD_MODIFY_DLG };
#endif

protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

	DECLARE_MESSAGE_MAP()
public:
	CString m_strName;
	CString m_strSex;
	int m_nAge;
	CString m_strDeparment;
	CString m_strJob;
	float m_fSalary;
	afx_msg void OnBnClickedModify();
};
cpp 复制代码
#include "pch.h"
#include "SQL.h"
#include "CModifyDlg.h"
#include "afxdialogex.h"


// CModifyDlg 对话框

IMPLEMENT_DYNAMIC(CModifyDlg, CDialogEx)

CModifyDlg::CModifyDlg(CWnd* pParent /*=nullptr*/)
	: CDialogEx(IDD_MODIFY_DLG, pParent)
	, m_strName(_T(""))
	, m_strSex(_T(""))
	, m_nAge(0)
	, m_strDeparment(_T(""))
	, m_strJob(_T(""))
	, m_fSalary(0)
{

}

CModifyDlg::~CModifyDlg()
{
}

void CModifyDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
	DDX_Text(pDX, IDC_EDIT2, m_strName);
	DDX_Text(pDX, IDC_EDIT1, m_strSex);
	DDX_Text(pDX, IDC_EDIT3, m_nAge);
	DDX_Text(pDX, IDC_EDIT4, m_strDeparment);
	DDX_Text(pDX, IDC_EDIT5, m_strJob);
	DDX_Text(pDX, IDC_EDIT6, m_fSalary);
}


BEGIN_MESSAGE_MAP(CModifyDlg, CDialogEx)
	ON_BN_CLICKED(IDC_MODIFY, &CModifyDlg::OnBnClickedModify)
END_MESSAGE_MAP()


// CModifyDlg 消息处理程序


void CModifyDlg::OnBnClickedModify()
{
	// TODO: 在此添加控件通知处理程序代码
	UpdateData();

	EndDialog(IDOK);
}
cpp 复制代码
void CSQLView::OnModify()
{
	CModifyDlg dlg;
	
	//获取数据
	POSITION pos = m_list.GetFirstSelectedItemPosition();
	int nSel = m_list.GetNextSelectedItem(pos);
	if (nSel < 0)
	{
		MessageBox(L"先选中在修改");
		return;
	}

	int workid = _wtoi(m_list.GetItemText(nSel, 0));

	dlg.m_strName = m_list.GetItemText(nSel,1);
	dlg.m_strSex= m_list.GetItemText(nSel, 2);
	dlg.m_nAge= _wtoi(m_list.GetItemText(nSel, 3));
	dlg.m_strDeparment= m_list.GetItemText(nSel, 4);
	dlg.m_strJob= m_list.GetItemText(nSel, 5);
	dlg.m_fSalary = _wtof(m_list.GetItemText(nSel, 6));

	if (IDCANCEL == dlg.DoModal())
		return;

	//修改数据库
	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql;
	                                               
	sql.Format(L"update user set sex=\'%s\',age=%d,department=\'%s\',job=\'%s\',salary=%f where name =\'%s\';",
		 dlg.m_strSex, dlg.m_nAge, dlg.m_strDeparment, dlg.m_strJob, dlg.m_fSalary, dlg.m_strName);

	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0, sql.GetBuffer(), sql.GetLength(), str, sizeof(str), NULL, NULL);
	int error = mysql.Query(str);
	if (error)
	{
		MessageBox(L"跟新失败");
		return;
	}
}

添加数据库类

创建数据库

sql 复制代码
//创建管理数据
create database mangerdata;

//创建用户表
create table user(
workid int primary key auto_increment,
name varchar(10) not null default '',
sex char(1) not null default '',
age tinyint unsigned not null default 0,
department varchar(10) not null default '',
job varchar(10) not null default '',
salary float not null default 0.0
);

配置数据库

导入数据库头文件

设置静态链接

将dll放入X64Debug中

产看连接MySQL函数

#include "mysql.h"

cpp 复制代码
class CMySQL
{
public:
	CMySQL();
	~CMySQL();
public:
	//连接数据库
	BOOL Connect(const char *host,const char *user,const char *passwd,const char *db,unsigned int port,const char *unix_socket,unsigned long client_flag);
	//执行SQL语句
	int Query(const char* str);
	//保存结果集
	MYSQL_RES* StoreResult();
	//检索结果集
	MYSQL_ROW FetchRow();
private:
	MYSQL* m_mysql;
	MYSQL_RES*  m_mysql_res;
public:
	MYSQL_ROW m_mysql_row;
};
cpp 复制代码
#include "pch.h"
#include "CMySQL.h"

#pragma comment(lib,"libmysql.lib")

CMySQL::CMySQL()
{
	m_mysql = mysql_init(NULL);
}

CMySQL::~CMySQL()
{
}

BOOL CMySQL::Connect(const char * host, const char * user, const char * passwd, const char * db, unsigned int port, const char * unix_socket, unsigned long client_flag)
{
	if (NULL == mysql_real_connect(m_mysql, host, user, passwd, db, port, unix_socket, client_flag))
	{
		return FALSE;
	}
	return TRUE;
	
}

int CMySQL::Query(const char * str)
{
	return mysql_real_query( m_mysql,str,strlen(str));
}

//保存结果集
MYSQL_RES * CMySQL::StoreResult()
{
	m_mysql_res=mysql_store_result(m_mysql);
	return m_mysql_res;
}

MYSQL_ROW CMySQL::FetchRow()
{
	m_mysql_row=mysql_fetch_row(m_mysql_res);
	return m_mysql_row;
}

全部代码

// SQLView.cpp: CSQLView 类的实现

cpp 复制代码
//

#include "pch.h"
#include "framework.h"
// SHARED_HANDLERS 可以在实现预览、缩略图和搜索筛选器句柄的
// ATL 项目中进行定义,并允许与该项目共享文档代码。
#ifndef SHARED_HANDLERS
#include "SQL.h"
#endif

#include "SQLDoc.h"
#include "SQLView.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

#include "CAddDlg.h"
#include "CMySQL.h"
#include "CModifyDlg.h"

// CSQLView

IMPLEMENT_DYNCREATE(CSQLView, CListView)

BEGIN_MESSAGE_MAP(CSQLView, CListView)
	// 标准打印命令
	ON_COMMAND(ID_FILE_PRINT, &CListView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, &CListView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, &CListView::OnFilePrintPreview)
	ON_COMMAND(IDM_ADD, &CSQLView::OnAdd)
	ON_COMMAND(IDM_DELETE, &CSQLView::OnDelete)
	ON_COMMAND(IDM_MODIFY, &CSQLView::OnModify)
END_MESSAGE_MAP()

// CSQLView 构造/析构

CSQLView::CSQLView() noexcept
	:m_list(GetListCtrl())
{
	// TODO: 在此处添加构造代码

}

CSQLView::~CSQLView()
{
}

BOOL CSQLView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: 在此处通过修改
	//  CREATESTRUCT cs 来修改窗口类或样式

	return CListView::PreCreateWindow(cs);
}


void CSQLView::OnDraw(CDC* /*pDC*/)
{
	CSQLDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	// TODO: 在此处为本机数据添加绘制代码
}


void CSQLView::OnInitialUpdate()
{
	CListView::OnInitialUpdate();

	m_list.ModifyStyle(0, LVS_REPORT);
	m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES);
	m_list.InsertColumn(0, L"id", LVCFMT_LEFT, 100);
	m_list.InsertColumn(1, L"姓名", LVCFMT_LEFT, 100);
	m_list.InsertColumn(2, L"性别", LVCFMT_LEFT, 100);
	m_list.InsertColumn(3, L"年龄", LVCFMT_LEFT, 100);
	m_list.InsertColumn(4, L"部门", LVCFMT_LEFT, 100);
	m_list.InsertColumn(5, L"岗位", LVCFMT_LEFT, 100);
	m_list.InsertColumn(6, L"薪资", LVCFMT_LEFT, 100);


	//修改数据库
	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql=L"select * from user";

	
	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0, sql.GetBuffer(), sql.GetLength(), str, sizeof(str), NULL, NULL);
	int error = mysql.Query(str);
	if (error)
	{
		MessageBox(L"查询失败");
		return;
	}


	mysql.StoreResult();
	int i = 0;
	//显示有问题
	while (mysql.FetchRow())
	{
		m_list.InsertItem(i,(wchar_t*)(mysql.m_mysql_row[0]));
		m_list.InsertItem(i, (wchar_t*)(mysql.m_mysql_row[1]));
		m_list.InsertItem(i, (wchar_t*)(mysql.m_mysql_row[2]));
		m_list.InsertItem(i, (wchar_t*)(mysql.m_mysql_row[3]));
	}
	
}




//添加
void CSQLView::OnAdd()
{
	CAddDlg dlg;
	if (IDCANCEL == dlg.DoModal())
		return;
	
	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql;
	sql.Format(L"insert into user(name,sex,age,department,job,salary) value (\'%s\',\'%s\',%d,\'%s\',\'%s\',%f);",
		dlg.m_strName,dlg.m_strSex,dlg.m_nAge,dlg.m_strDeparment,dlg.m_strJob,dlg.m_fSalary);

	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0,sql.GetBuffer(),sql.GetLength(),str,sizeof(str),NULL,NULL);
	int error=mysql.Query(str);
	if(error)
	{
		MessageBox(L"添加失败");
		return;
	}
	MessageBox(L"添加成功");
	//插入到列表
	int nCount = m_list.GetItemCount();
	CString str1;
	str1.Format(L"%d", nCount);
	m_list.InsertItem(nCount, str1);
	m_list.SetItemText(nCount, 1, dlg.m_strName);
	m_list.SetItemText(nCount, 2, dlg.m_strSex);
	str1.Format(L"%d", dlg.m_nAge);
	m_list.SetItemText(nCount, 3, str1);
	m_list.SetItemText(nCount, 4, dlg.m_strDeparment);
	m_list.SetItemText(nCount, 5, dlg.m_strJob);
	str1.Format(L"%.2f", dlg.m_fSalary);
	m_list.SetItemText(nCount, 6, str1);

}

//删除
void CSQLView::OnDelete()
{
	POSITION pos=m_list.GetFirstSelectedItemPosition();
	int nSel = m_list.GetNextSelectedItem(pos);
	if (nSel<0)
	{
		MessageBox(L"先选中在删除");
		return;
	}

	CString strDelete = m_list.GetItemText(nSel, 1);

	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql;
	sql.Format(L"delete from user where name=\'%s\';", strDelete);

	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0, sql.GetBuffer(), sql.GetLength(), str, sizeof(str), NULL, NULL);
	int error = mysql.Query(str);
	if (error)
	{
		MessageBox(L"删除失败");
		return;
	}
	m_list.DeleteItem(nSel);
}



void CSQLView::OnModify()
{
	CModifyDlg dlg;
	
	//获取数据
	POSITION pos = m_list.GetFirstSelectedItemPosition();
	int nSel = m_list.GetNextSelectedItem(pos);
	if (nSel < 0)
	{
		MessageBox(L"先选中在修改");
		return;
	}

	int workid = _wtoi(m_list.GetItemText(nSel, 0));

	dlg.m_strName = m_list.GetItemText(nSel,1);
	dlg.m_strSex= m_list.GetItemText(nSel, 2);
	dlg.m_nAge= _wtoi(m_list.GetItemText(nSel, 3));
	dlg.m_strDeparment= m_list.GetItemText(nSel, 4);
	dlg.m_strJob= m_list.GetItemText(nSel, 5);
	dlg.m_fSalary = _wtof(m_list.GetItemText(nSel, 6));

	if (IDCANCEL == dlg.DoModal())
		return;

	//修改数据库
	CMySQL mysql;
	if (FALSE == mysql.Connect("localhost", "root", "123456", "mangerdata", 3306, NULL, NULL))
	{
		MessageBox(L"连接数据库失败");
		return;
	}

	mysql.Query("set names GBK");//设置编码

	//插入数据
	CString sql;
	                                               
	sql.Format(L"update user set sex=\'%s\',age=%d,department=\'%s\',job=\'%s\',salary=%f where name =\'%s\';",
		 dlg.m_strSex, dlg.m_nAge, dlg.m_strDeparment, dlg.m_strJob, dlg.m_fSalary, dlg.m_strName);

	//转换成窄字符串
	char str[500] = { 0 };
	WideCharToMultiByte(CP_ACP, 0, sql.GetBuffer(), sql.GetLength(), str, sizeof(str), NULL, NULL);
	int error = mysql.Query(str);
	if (error)
	{
		MessageBox(L"跟新失败");
		return;
	}


}

// CAddDlg 对话框

cpp 复制代码
class CAddDlg : public CDialogEx
{
	DECLARE_DYNAMIC(CAddDlg)

public:
	CAddDlg(CWnd* pParent = nullptr);   // 标准构造函数
	virtual ~CAddDlg();

// 对话框数据
#ifdef AFX_DESIGN_TIME
	enum { IDD = IDD_ADD_DLG };
#endif

protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

	DECLARE_MESSAGE_MAP()
public:
	CString m_strName;
	CString m_strSex;
	int m_nAge;
	CString m_strDeparment;
	CString m_strJob;
	float m_fSalary;
	afx_msg void OnBnClickedAdd();
	
};

// CAddDlg.cpp: 实现文件

cpp 复制代码
//

#include "pch.h"
#include "SQL.h"
#include "CAddDlg.h"
#include "afxdialogex.h"


// CAddDlg 对话框

IMPLEMENT_DYNAMIC(CAddDlg, CDialogEx)

CAddDlg::CAddDlg(CWnd* pParent /*=nullptr*/)
	: CDialogEx(IDD_ADD_DLG, pParent)
	, m_strName(_T(""))
	, m_strSex(_T(""))
	, m_nAge(0)
	, m_strDeparment(_T(""))
	, m_strJob(_T(""))
	, m_fSalary(0)
{

}

CAddDlg::~CAddDlg()
{
}

void CAddDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
	DDX_Text(pDX, IDC_EDIT2, m_strName);
	DDX_Text(pDX, IDC_EDIT1, m_strSex);
	DDX_Text(pDX, IDC_EDIT3, m_nAge);
	DDX_Text(pDX, IDC_EDIT4, m_strDeparment);
	DDX_Text(pDX, IDC_EDIT5, m_strJob);
	DDX_Text(pDX, IDC_EDIT6, m_fSalary);
}


BEGIN_MESSAGE_MAP(CAddDlg, CDialogEx)
	ON_BN_CLICKED(IDC_ADD, &CAddDlg::OnBnClickedAdd)
	
END_MESSAGE_MAP()


// CAddDlg 消息处理程序


void CAddDlg::OnBnClickedAdd()
{
	UpdateData();
	EndDialog(IDOK);
}

// CModifyDlg 对话框

cpp 复制代码
class CModifyDlg : public CDialogEx
{
	DECLARE_DYNAMIC(CModifyDlg)

public:
	CModifyDlg(CWnd* pParent = nullptr);   // 标准构造函数
	virtual ~CModifyDlg();

// 对话框数据
#ifdef AFX_DESIGN_TIME
	enum { IDD = IDD_MODIFY_DLG };
#endif

protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

	DECLARE_MESSAGE_MAP()
public:
	CString m_strName;
	CString m_strSex;
	int m_nAge;
	CString m_strDeparment;
	CString m_strJob;
	float m_fSalary;
	afx_msg void OnBnClickedModify();
};

// CModifyDlg.cpp: 实现文件

cpp 复制代码
//

#include "pch.h"
#include "SQL.h"
#include "CModifyDlg.h"
#include "afxdialogex.h"


// CModifyDlg 对话框

IMPLEMENT_DYNAMIC(CModifyDlg, CDialogEx)

CModifyDlg::CModifyDlg(CWnd* pParent /*=nullptr*/)
	: CDialogEx(IDD_MODIFY_DLG, pParent)
	, m_strName(_T(""))
	, m_strSex(_T(""))
	, m_nAge(0)
	, m_strDeparment(_T(""))
	, m_strJob(_T(""))
	, m_fSalary(0)
{

}

CModifyDlg::~CModifyDlg()
{
}

void CModifyDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
	DDX_Text(pDX, IDC_EDIT2, m_strName);
	DDX_Text(pDX, IDC_EDIT1, m_strSex);
	DDX_Text(pDX, IDC_EDIT3, m_nAge);
	DDX_Text(pDX, IDC_EDIT4, m_strDeparment);
	DDX_Text(pDX, IDC_EDIT5, m_strJob);
	DDX_Text(pDX, IDC_EDIT6, m_fSalary);
}


BEGIN_MESSAGE_MAP(CModifyDlg, CDialogEx)
	ON_BN_CLICKED(IDC_MODIFY, &CModifyDlg::OnBnClickedModify)
END_MESSAGE_MAP()


// CModifyDlg 消息处理程序


void CModifyDlg::OnBnClickedModify()
{
	// TODO: 在此添加控件通知处理程序代码
	UpdateData();

	EndDialog(IDOK);
}
cpp 复制代码
#pragma once
#include "mysql.h"
class CMySQL
{
public:
	CMySQL();
	~CMySQL();
public:
	//连接数据库
	BOOL Connect(const char *host,const char *user,const char *passwd,const char *db,unsigned int port,const char *unix_socket,unsigned long client_flag);
	//执行SQL语句
	int Query(const char* str);
	//保存结果集
	MYSQL_RES* StoreResult();
	//检索结果集
	MYSQL_ROW FetchRow();
private:
	MYSQL* m_mysql;
	MYSQL_RES*  m_mysql_res;
public:
	MYSQL_ROW m_mysql_row;

};
cpp 复制代码
#include "pch.h"
#include "CMySQL.h"

#pragma comment(lib,"libmysql.lib")

CMySQL::CMySQL()
{
	m_mysql = mysql_init(NULL);
}

CMySQL::~CMySQL()
{
}

BOOL CMySQL::Connect(const char * host, const char * user, const char * passwd, const char * db, unsigned int port, const char * unix_socket, unsigned long client_flag)
{
	if (NULL == mysql_real_connect(m_mysql, host, user, passwd, db, port, unix_socket, client_flag))
	{
		return FALSE;
	}
	return TRUE;
	
}

int CMySQL::Query(const char * str)
{
	return mysql_real_query( m_mysql,str,strlen(str));
}

//保存结果集
MYSQL_RES * CMySQL::StoreResult()
{
	m_mysql_res=mysql_store_result(m_mysql);
	return m_mysql_res;
}

MYSQL_ROW CMySQL::FetchRow()
{
	m_mysql_row=mysql_fetch_row(m_mysql_res);
	return m_mysql_row;
}
相关推荐
Syntech_Wuz2 分钟前
从 C 到 C++:容器适配器 std::stack 与 std::queue 详解
数据结构·c++·容器··队列
CryptoRzz17 分钟前
欧美(美股、加拿大股票、墨西哥股票)股票数据接口文档
java·服务器·开发语言·数据库·区块链
APItesterCris1 小时前
构建弹性数据管道:利用淘宝商品 API 进行流式数据采集与处理
linux·数据库·windows
九河云1 小时前
TOS + 数字孪生:集装箱码头的智能进化密码
大数据·服务器·网络·数据库·数字化转型
艾莉丝努力练剑1 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
胡萝卜3.01 小时前
深入理解string底层:手写高效字符串类
开发语言·c++·学习·学习笔记·string类·string模拟实现
kyle~1 小时前
计算机系统---CPU的进程与线程处理
linux·服务器·c语言·c++·操作系统·计算机系统
手握风云-1 小时前
MySQL数据库精研之旅第十九期:存储过程,数据处理的全能工具箱(二)
数据库·mysql
孟意昶1 小时前
Doris专题17- 数据导入-文件格式
大数据·数据库·分布式·sql·doris
你可以永远相信功夫熊猫2 小时前
金蝶云·星瀚 | 生产制造成本核算终极实操手册(从0到1,含两套完整案例)
数据库·erp