⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 userdlg.cpp

📁 学生成绩管理系统,可以对学生的成绩修改,删除,添加,查询等操作
💻 CPP
字号:
// UserDlg.cpp : implementation file
//

#include "stdafx.h"
#include "StudentScore.h"
#include "UserDlg.h"
#include "UserSet.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CUserDlg dialog


CUserDlg::CUserDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CUserDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CUserDlg)
	//}}AFX_DATA_INIT
}


void CUserDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CUserDlg)
	DDX_Control(pDX, ID_USER_OK, m_bConfirm);
	DDX_Control(pDX, IDC_USER_PASSWORD, m_strPassword);
	DDX_Control(pDX, IDC_USER_NAME, m_strUser);
	DDX_Control(pDX, IDC_USER_LEVEL, m_cLevel);
	DDX_Control(pDX, ID_USER_EDIT, m_bEdit);
	DDX_Control(pDX, ID_USER_DEL, m_bDel);
	DDX_Control(pDX, ID_USER_ADD, m_bAdd);
	DDX_Control(pDX, IDC_LIST_USER, m_list);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CUserDlg, CDialog)
	//{{AFX_MSG_MAP(CUserDlg)
	ON_BN_CLICKED(ID_USER_ADD, OnUserAdd)
	ON_BN_CLICKED(ID_USER_EDIT, OnUserEdit)
	ON_BN_CLICKED(ID_USER_DEL, OnUserDel)
	ON_NOTIFY(NM_CLICK, IDC_LIST_USER, OnClickListUser)
	ON_BN_CLICKED(ID_USER_OK, OnUserOk)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CUserDlg message handlers


BOOL CUserDlg::OnInitDialog()
{
	CDialog::OnInitDialog();
	//初始化里CList 控件的和header
	m_list.InsertColumn(0,"用户编号");
    m_list.InsertColumn(1,"用户名");
    m_list.InsertColumn(2,"密码");
	m_list.InsertColumn(3,"用户权限");
	//设置header的宽度
    RECT rectList;
	m_list.GetWindowRect(&rectList);
	int wid=rectList.right-rectList.left-4;
	for(int i=0;i<4;i++)
		m_list.SetColumnWidth(i,wid/4);
    m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT);
	//调用refreshList()初始化CList中的数据
	RefreshList();
	//为权限的下拉列表添加item
	m_cLevel.AddString("管理员");
	m_cLevel.AddString("教师");
	m_cLevel.AddString("学生");
	//设置第一个item为选中状态
	m_cLevel.SelectString(0,"管理员");
    //调用ResetButton()方法,使按钮处于初始状态
	ResetButton();
	return TRUE;
}

void CUserDlg::OnUserAdd() //添加按钮方法
{
	//设置输入框为可编辑状态并清空输入框中的值
	m_strUser.EnableWindow(true);
    m_strUser.SetWindowText("");
    m_strPassword.EnableWindow(true);
    m_strPassword.SetWindowText("");
	m_cLevel.EnableWindow(true);
	m_cLevel.SelectString(0,"管理员");
	//打开记录集
    m_userSet.Open();
	//添加新记录
	m_userSet.AddNew();
	//设置点击确定按钮后,其他按钮的状态
	m_bConfirm.EnableWindow(true);
    m_bAdd.EnableWindow(false);
	m_bEdit.EnableWindow(false);
	m_bDel.EnableWindow(false);
	
}

void CUserDlg::RefreshList()//更新CList中的数据
{   
	//删除CList的所有内容
	m_list.DeleteAllItems();
	//打开记录集
    m_userSet.Open();
	//设置查询条件
    m_userSet.m_strFilter="active_status='Y'";
	//执行查询
    m_userSet.Requery();
	//将记录集显示到 CList中
	for(int i=0;i<m_userSet.GetRecordCount();i++){
		CString temp;
		m_userSet.GetFieldValue("user_id",temp);
		m_list.InsertItem(i,temp);
		m_userSet.GetFieldValue("user_name",temp);
		m_list.SetItemText(i,1,temp);
        m_userSet.GetFieldValue("user_password",temp);
		m_list.SetItemText(i,2,temp);
		m_userSet.GetFieldValue("user_level",temp);
		m_list.SetItemText(i,3,temp);
        m_userSet.MoveNext();
	}
	//关闭数据库
	m_userSet.Close();
}

void CUserDlg::OnUserEdit() //修改按钮方法
{
	//得到CList当前所选的行号
	int row=m_list.GetSelectionMark();
	CString s,strSQL;
	//将当前行的第一列的值赋给s
	s=m_list.GetItemText(row,0);
	if(s=="")//如果s为空,则表示没有选中行
	{
		MessageBox("请选择一行!");
	}
	else//如果有选中一行
	{
		//定义查询条件,相当于where
		strSQL.Format("user_id=%s",s);
		//打开记录集
		m_userSet.Open();
		//设置查询条件
		m_userSet.m_strFilter=strSQL;
		//执行查询
		m_userSet.Requery();
		//游标指定到该行所在的记录上,执行修改
		m_userSet.Edit();
		//设置点击修改按钮后其他按钮的状态
		m_bConfirm.EnableWindow(true);
		m_bAdd.EnableWindow(false);
		m_bEdit.EnableWindow(false);
		m_bDel.EnableWindow(false);
		m_strUser.EnableWindow(true);
		m_strPassword.EnableWindow(true);
		m_cLevel.EnableWindow(true);
	}
}

void CUserDlg::OnUserDel() //删除按钮方法
{   
	//得到CList当前所选的行号
	int row=m_list.GetSelectionMark();
	CString s,strSQL;
	//将当前行的第一列的值赋给s
	s=m_list.GetItemText(row,0);
	if(s=="")//如果s为空,则表示没有选中行
	{
		MessageBox("请选择一行!");
	}
	else
	{
		//弹出窗口询问是否删除数据
		if(MessageBox("确定要删除记录吗?","删除询问",MB_OKCANCEL|MB_ICONQUESTION)==IDOK)
		{
			//查询所选行所在的记录
			strSQL.Format("user_id=%s",s);
			m_userSet.Open();
			m_userSet.m_strFilter=strSQL;
			m_userSet.Requery();
			m_userSet.Edit();
			//设置active_status="N";
			m_userSet.m_active_status="N";
			//更新数据库
			m_userSet.Update();
			//关闭数据库
			m_userSet.Close();
			//更新CList数据
			RefreshList();
		}
	}
}

void CUserDlg::OnCancel()//取消按钮方法 
{
	if(m_userSet.IsOpen())//如果记录集打开,则关闭记录集
		m_userSet.Close();
	ResetButton();
	CDialog::OnCancel();
}


void CUserDlg::OnClickListUser(NMHDR* pNMHDR, LRESULT* pResult) //选中Clist中某一行是的事件方法
{
	//当选中CList中某一行时,将CList中的数据也显示到编辑框中
	//获得所选行的行号
	int row=m_list.GetSelectionMark();
	CString s;
	//将第2列的值赋给临时字符串s中
	s=m_list.GetItemText(row,1);
	//相应的编辑框显示该值
	m_strUser.SetWindowText(s);
    s=m_list.GetItemText(row,2);
	m_strPassword.SetWindowText(s);
    //将第4列的值赋给临时字符串s中
	s=m_list.GetItemText(row,3);
	if(s=="0")//如果s为0,则设置下拉列表值为管理员
	{
		m_cLevel.SelectString(0,"管理员");
	}
	else if(s=="1")//如果s为1,则设置下拉列表值为 教师
	{
		m_cLevel.SelectString(1,"教师");
	}
	else if(s=="2")//如果s为2,则设置下拉列表值为学生
	{
		m_cLevel.SelectString(2,"学生");
	}
	
	*pResult = 0;
}

void CUserDlg::OnUserOk() //确定按钮方法
{
	CString username,password,level;
	//得到输入编辑框的值
	m_strUser.GetWindowText(username);
	m_strPassword.GetWindowText(password);
	if(username=="")//如果用户名为空
	{
	   MessageBox("请输入用户名");
	}
	else if(password=="")//如果密码为空
	{
		MessageBox("请输入密码");
	}
	else
	{
		//获取下拉列表中的值 
		int i=m_cLevel.GetCurSel();	
		if(i==0)
			level="0";
		if(i==1)
			level="1";
		if(i==2)
			level="2";	
		//设置记录添加或编辑后的值
		m_userSet.m_user_name=username;
		m_userSet.m_user_password=password;
		m_userSet.m_user_level=level;
		m_userSet.m_active_status="Y";
		//更新记录集
		m_userSet.Update();
		//关闭记录集
		m_userSet.Close();
		RefreshList();
		ResetButton();
	}
}

void CUserDlg::ResetButton()//设置按钮的初始状态
{
	//设置用户名,密码,权限编辑框不可用
	m_strUser.EnableWindow(false);
    m_strPassword.EnableWindow(false);
	m_cLevel.EnableWindow(false);
	//设置确定按钮不可用
	m_bConfirm.EnableWindow(false);
	//设置添加、删除、编辑按钮可用状态
	m_bAdd.EnableWindow(true);
	m_bDel.EnableWindow(true);
	m_bEdit.EnableWindow(true);
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -