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

📄 mainfrm.cpp

📁 一个用户信息管理模块
💻 CPP
字号:
// MainFrm.cpp : implementation of the CMainFrame class
//

#include "stdafx.h"
#include "Demo02.h"

#include "MainFrm.h"

//增加CUserSearchDlg的引用申明
#include "UserSearchDlg.h"

//增加CDemo02View的引用申明
#include "Demo02View.h"

//增加CUserDlg的引用申明
#include "UserDlg.h"

//增加CDemo02View的引用申明
#include "UserRecordSet.h"

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

/////////////////////////////////////////////////////////////////////////////
// CMainFrame

IMPLEMENT_DYNCREATE(CMainFrame, CFrameWnd)

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
	//{{AFX_MSG_MAP(CMainFrame)
	ON_WM_CREATE()
	ON_COMMAND(ID_USER_ADD, OnUserAdd)
	ON_COMMAND(ID_USER_DEL, OnUserDel)
	ON_COMMAND(ID_USER_EDIT, OnUserEdit)
	ON_COMMAND(ID_USER_LIST, OnUserList)
	ON_COMMAND(ID_BUTTON_USER_ADD, OnButtonUserAdd)
	ON_COMMAND(ID_BUTTON_USER_DEL, OnButtonUserDel)
	ON_COMMAND(ID_BUTTON_USER_EDIT, OnButtonUserEdit)
	ON_COMMAND(ID_BUTTON_USER_LIST, OnButtonUserList)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

static UINT indicators[] =
{
	ID_SEPARATOR,           // status line indicator
	ID_INDICATOR_CAPS,
	ID_INDICATOR_NUM,
	ID_INDICATOR_SCRL,
};

/////////////////////////////////////////////////////////////////////////////
// CMainFrame construction/destruction

CMainFrame::CMainFrame()
{
	// TODO: add member initialization code here
}

CMainFrame::~CMainFrame()
{
}

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
	if (CFrameWnd::OnCreate(lpCreateStruct) == -1)
		return -1;
	
	if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP
		| CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
		!m_wndToolBar.LoadToolBar(IDR_MAINFRAME))
	{
		TRACE0("Failed to create toolbar\n");
		return -1;      // fail to create
	}

	if (!m_wndStatusBar.Create(this) ||
		!m_wndStatusBar.SetIndicators(indicators,
		  sizeof(indicators)/sizeof(UINT)))
	{
		TRACE0("Failed to create status bar\n");
		return -1;      // fail to create
	}

	// TODO: Delete these three lines if you don't want the toolbar to
	//  be dockable
	m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
	EnableDocking(CBRS_ALIGN_ANY);
	DockControlBar(&m_wndToolBar);

	return 0;
}

BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs)
{
	if( !CFrameWnd::PreCreateWindow(cs) )
		return FALSE;
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return TRUE;
}

/////////////////////////////////////////////////////////////////////////////
// CMainFrame diagnostics

#ifdef _DEBUG
void CMainFrame::AssertValid() const
{
	CFrameWnd::AssertValid();
}

void CMainFrame::Dump(CDumpContext& dc) const
{
	CFrameWnd::Dump(dc);
}

#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMainFrame message handlers

void CMainFrame::OnUserAdd() 
{
	// TODO: Add your command handler code here
	//创建CUserDlg的实例
	CUserDlg m_UserDlg;
	//弹出增加用户信息的对话框,如果点击了"取消按钮",则退出
	if(m_UserDlg.DoModal() != IDOK)
		return;
	//如果点击了确定按钮,则开始数据库操作

	//创建CUserRecordSet的实例
	CUserRecordSet m_UserRecordSet;
	try
	{
		if(m_UserRecordSet.IsOpen())
			m_UserRecordSet.Close();
		
		//设置查询条件"UserName=strUserName"
		m_UserRecordSet.m_strFilter.Format("UserName = '%s' order by UserID ASC",
			m_UserDlg.m_UserName.operator LPCTSTR());
		//执行查询
		m_UserRecordSet.Open(CRecordset::snapshot,NULL,CRecordset::none);
		//判断数据库中是否有同名用户,如果有,则退出
		if(!m_UserRecordSet.IsEOF())
		{
			//关闭记录集
			m_UserRecordSet.Close();
			//弹出警告信息
			AfxMessageBox("同名用户已经存在");
			//退出函数处理
			return;
		}
		//如果没有同名用户,则执行正常的添加操作
		//首先增加一条新记录
		m_UserRecordSet.AddNew();
		//然后编辑该条记录的内容
		m_UserRecordSet.m_UserAble = m_UserDlg.m_UserAble;
		m_UserRecordSet.m_UserAddr = m_UserDlg.m_UserAddr;
		m_UserRecordSet.m_UserDep = m_UserDlg.m_UserDep;
		m_UserRecordSet.m_UserEmail = m_UserDlg.m_UserEmail;
		m_UserRecordSet.m_UserInfo = m_UserDlg.m_UserInfo;
		m_UserRecordSet.m_UserName = m_UserDlg.m_UserName;
		m_UserRecordSet.m_UserPhone = m_UserDlg.m_UserPhone;
		m_UserRecordSet.m_UserPwd = m_UserDlg.m_UserPwd;
		m_UserRecordSet.m_UserSex = m_UserDlg.m_UserSex;
		m_UserRecordSet.m_UserTitle = m_UserDlg.m_UserTitle;
		//最后,将用户信息更新到数据库中
		//更新时,要判断当前是否能够进行更新操作
        if(m_UserRecordSet.CanUpdate())
		{
			m_UserRecordSet.Update();			
		}
		//关闭记录集
		if(m_UserRecordSet.IsOpen())
			m_UserRecordSet.Close();
		//弹出“添加成功”的提示信息
		AfxMessageBox("用户信息增加成功!");
	}
	//意外捕获
	catch(CDBException*e)
	{
		e->ReportError ();
		//e->Delete ();
		return;
	}
}

void CMainFrame::OnUserDel() 
{
	// TODO: Add your command handler code here
	//增加删除确认,用户选择“确定”之后,方删除记录
	if (MessageBox("是否删除这条记录?","删除确认",MB_YESNO|MB_ICONQUESTION)==IDYES)
	{
		//执行删除操作
		m_ListView->DelCurUser();	
	}
}

void CMainFrame::OnUserEdit() 
{
	// TODO: Add your command handler code here
	m_ListView->EditCurUser();
}

void CMainFrame::OnUserList() 
{
	// TODO: Add your command handler code here

	//调用CUserSearchDlg,输入查询条件。

	//创建CUserSearchDlg的实例
	CUserSearchDlg m_SearchDlg;
	//弹出查询对话框,如果点击了"取消按钮",则退出
	if(m_SearchDlg.DoModal() == IDOK)
	{
		BOOL bIsFirst = TRUE;
		CString strSql,strUserSearch,strUserID;
		if(m_SearchDlg.m_strUserSearch!="")
		{
			strUserSearch="strUserSearch='"+m_SearchDlg.m_strUserSearch+"'";
			bIsFirst=FALSE;
		}
		else if
			strUserSearch="";
		if(m_SearchDlg.m_strUserID!="")
		{
			if( bIsFirst == TRUE )
				strUserID="strUserID='"+m_SearchDlg.m_strUserID+"'";
			else
				strUserID="and strUserID='"+m_SearchDlg.m_strUserID+"'";
			bIsFirst = FALSE;
		}
	if( bIsFirst == TRUE )	//没有输入任何条件
			strSql = "select * from pUser";
	else
			strSql = "select * from pUser where" + strUserSearch + strUserID; 
	//如果选择了"确定"按钮,则执行以下操作,输出符合条件的用户信息
	m_ListView->ListUser(strSql);
}

void CMainFrame::OnButtonUserAdd() 
{
	// TODO: Add your command handler code here
	OnUserAdd();
}

void CMainFrame::OnButtonUserDel() 
{
	// TODO: Add your command handler code here
	OnUserDel();
}

void CMainFrame::OnButtonUserEdit() 
{
	// TODO: Add your command handler code here
	OnUserEdit();	
}

void CMainFrame::OnButtonUserList() 
{
	// TODO: Add your command handler code here
	OnUserList();
}

⌨️ 快捷键说明

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