MFC 基于数据库的管理系统

news2025/2/4 8:40:20

文章目录

  • 初始化
    • 设置菜单
  • 添加数据库类
    • 创建数据库
    • 配置数据库
  • 全部代码

初始化

创建文件选择基于CListView
在这里插入图片描述

初始化数据

public:
	CListCtrl& m_list;
CSQLView::CSQLView() noexcept
	:m_list(GetListCtrl())
{
	// 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]));
	}
}

设置菜单

添加
在这里插入图片描述在这里插入图片描述
创建添加类
在这里插入图片描述 每一个控件都添加控件变量
在这里插入图片描述

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: 实现文件

//

#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);
}
//添加
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);
}

修改
在这里插入图片描述
在这里插入图片描述
设置添加对话框
在这里插入图片描述添加修改类
在这里插入图片描述// CModifyDlg 对话框

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();
};
#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);
}
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;
	}
}

添加数据库类

创建数据库

//创建管理数据
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”

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;
};
#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 类的实现

//

#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 对话框

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: 实现文件

//

#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 对话框

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: 实现文件

//

#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);
}
#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;

};
#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;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/761933.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RK3588 CPU GPU NPU 定频和性能模式设置方法以及温度监控

一. CPU定频 1. RK3588的cpu是4个A554个A76&#xff0c;分为3组单独管理&#xff0c;节点分别是&#xff1a; /sys/devices/system/cpu/cpufreq/policy0&#xff08;对应四个A55:CPU0-CPU3&#xff09; /sys/devices/system/cpu/cpufreq/policy4&#xff08;对应2个A76:CPU4-…

【Java从0到1学习】01 Java 概述

1. Java概述 Java 是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 面向对象程序设计语言和 Java 平台的总称。由 James Gosling和同事们共同研发&#xff0c;并在 1995 年正式推出。 后来 Sun 公司被 Oracle &#xff08;甲骨文&#xff09;公司收购&#xff0c;Java…

微信小程序基于Promise封装发起网络请求

1.创建一个request.js // 相当于域名 const baseURL ***************; // 暴露一个request函数 export function request(parms) {// 路径拼接const url baseURL parms.url;// 请求体&#xff0c;默认为{}const data parms.data || {};// 请求方式&#xff0c;默认为GETco…

<Babel> 前端语言的巴别塔

Babel中文站点&#xff1a;https://www.babeljs.cn/ Babel外文站点&#xff1a;https://babeljs.io/ 什么是Babel Babel取自人类语言最早的传说&#xff0c;Tower of Babel。 上帝摧毁了巴别塔上说着共同语言的我们&#xff0c;又被Babel重新带了回来。 如果说巴别塔是人们对混…

windows命令行运行mysql

1.运行命令&#xff1a;mysql -u用户名 -p密码 2.创建数据库&#xff1a; create 数据库名称 &#xff1b; 3.use 数据库 4.show tables &#xff1b; 5.创建用户&#xff0c;分配权限 6.退出 ctrlc 7.切换用户

海外app在谷歌和苹果商店中该如何设置关键词

主导应用商店搜索结果的方法就是关键词的设置。我们需要寻找关键词&#xff0c;跟踪关键词排名并监控其应用的性能&#xff0c;这样就能大大的提高应用的可见度。 优先考虑可推动Android或ios应用自然下载量的关键词&#xff0c;使用搜索量指标了解某个关键词在应用商店中的搜…

数字孪生很火嘛?是做什么的?

数字孪生是一种新兴的技术概念&#xff0c;将现实世界与数字世界紧密结合&#xff0c;通过数字化的方式模拟、仿真和预测真实世界的物理实体、过程和系统。它是物理实体与其数字化的虚拟模型之间的一种互联关系&#xff0c;旨在实现对现实世界的全面感知和实时监测。 数字孪生的…

骑行健身,生活和工作压力的避风港

在忙碌的现代生活中&#xff0c;每个人都面临着种种生活压力和工作压力。而自行车运动&#xff0c;正是一种理想的压力释放方式。它不仅能帮助我们保持身体健康&#xff0c;更能丰富我们的生活&#xff0c;让我们在自然中寻找宁静。 首先&#xff0c;骑自行车是一种全身性的运动…

BigTable:一个针对结构化数据的分布式存储系统----论文摘要

目录 摘要 1. 介绍 2. 数据模型 行 列族 时间戳 3. API 4. 所需构件 5. 实现 5.1 Tablet的位置 5.2 Tablet分配 5.3 Tablet服务 5.4 压实&#xff08;Compactions&#xff09; 6. 优化 本地化分组 压缩(compression) 通过缓存提高读操作的性能 Bloom过滤器 C…

2023年7月16日,HashMap

HashMap HashMap存储的是一组无序的键值对。存储时是根据键的哈希码来计算存储的位置&#xff0c;因为对象的哈希码是不确定的&#xff0c;因此HashMap存储的元素是无序的。 Map用于保存具有映射关系的数据&#xff0c;Map里保存着两组数据&#xff1a;key和value&#xff0c;它…

Leetcode-每日一题【2487.从链表中移除节点】

题目 给你一个链表的头节点 head 。 对于列表中的每个节点 node &#xff0c;如果其右侧存在一个具有 严格更大 值的节点&#xff0c;则移除 node 。 返回修改后链表的头节点 head 。 示例 1&#xff1a; 输入&#xff1a;head [5,2,13,3,8]输出&#xff1a;[13,8]解释&…

拒绝被其他域名恶意解析到你的服务器上

拒绝被其他域名恶意解析到你的服务器上 备案问题恶意解析解决方案后记 备案问题 新的一周开始了&#xff0c;又是一个摸鱼的好时候。。。。结果&#xff0c;刚刚坐到工位上&#xff0c;机房客服发来了一个 excel &#xff0c;说。。。你的备案信息没完善。。。 啥&#xff1f…

C语言进阶之程序环境和预处理

程序环境和预处理 1. 程序的翻译环境和执行环境2. 详解编译链接2.1 翻译环境2.2 编译的几个阶段2.3 运行环境 3. 预处理详解3.1 预定义符号3.2 #define3.2.1 #define 定义标识符3.2.2 #define 定义宏3.2.3 #define 替换规则3.2.4 #和##3.2.5 带副作用的宏参数3.2.6 宏和函数对比…

快速搭建接口自动化测试框架

1 接口测试 接口测试是对系统或组件之间的接口进行测试&#xff0c;主要是校验数据的交换&#xff0c;传递和控制管理过程&#xff0c;以及相互逻辑依赖关系。 接口自动化相对于UI自动化来说&#xff0c;属于更底层的测试&#xff0c;这样带来的好处就是测试收益更大&#xff…

Python基础教程:数据结构

Python是一门广泛使用的编程语言&#xff0c;它的丰富的数据结构使得编写程序变得异常简单和方便。在本篇教程中&#xff0c;我将详细介绍Python中的四种主要数据结构&#xff1a;列表、元组、字典、集合。 1.列表&#xff08;List&#xff09; 列表是Python中最常用的数据结…

Nginx代理Grafana,鉴权访问以及Grafan免登录访问

✨概述 在使用grafana做页面嵌入的场景中&#xff0c;通常需要grafana与前端在同域下&#xff0c;方便鉴权、解决跨域。 Nginx代理Grafana后&#xff0c;就不能使用Grafana中默认配置的端口和路径进行访问&#xff0c;必须通过Nginx访问Grafana。 如果需要做Iframe嵌入自研系…

RabbitMQ ---- 发布高级确认

RabbitMQ ---- 发布高级确认 1. 发布确认 springboot 版本1.1 确认机制方案1.2 代码架构图1.3 配置文件1.4 添加配置类1.5 消息生产者1.6 回调接口1.7 消息消费者1.8 结果分析 2. 回退消息2.1 Mandatory 参数2.2 回调接口2.3 结果分析 3. 备份交换机3.1 代码架构图3.2 修改配置…

CAD可以转换成PDF吗?教你简单好用的转换方法

PDF格式是一种通用格式&#xff0c;可以在不同的设备和操作系统上轻松打开和查看&#xff0c;这使得共享和协作变得更加容易和高效。尤其是在远程工作的情况下&#xff0c;PDF格式能够让团队成员更方便地分享和合作&#xff0c;不受地理位置和设备的限制。那么怎么将CAD文件转换…

7. Java + Selenium 环境搭建

前提&#xff1a;Java 版本最低要求为 8&#xff1b;推荐使用 chrome 浏览器 chrome Java 1. 下载 chrome 浏览器&#xff08;推荐&#xff09; 2. 查看 chrome 浏览器版本 重点记住前两位即可。 3. 下载 chrome 浏览器驱动 下载链接&#xff1a; https://chromedriver.…

IPD跟敏捷、DevOps一样吗?有什么区别?

1992年在激烈的全球市场竞争下&#xff0c;IBM遭遇到了严重的财政困难&#xff0c;公司销售收入停止增长&#xff0c;利润急剧下降。经过内部分析&#xff0c;IBM发现他们在研发费用、研发损失费用和产品上市时间等几个方面远远落后于业界最佳。为了重新获得市场竞争优势&#…