📄 classview.cpp
字号:
// ClassView.cpp : implementation file
//
#include "stdafx.h"
#include "TestApp.h"
#include "ClassView.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CClassView
IMPLEMENT_DYNCREATE(CClassView, CRecordView)
CClassView::CClassView()
: CRecordView(CClassView::IDD)
{
//{{AFX_DATA_INIT(CClassView)
m_pSet = NULL;
m_recnews = _T("");
m_recno=0;//初始化当前记录号
m_reccount=0;//初始化记录总数
//}}AFX_DATA_INIT
}
CClassView::~CClassView()
{
((CTestAppApp*)AfxGetApp())->m_ClassViews=0;//启用显示班级信息管理窗口菜单命令
if (m_pSet)
delete m_pSet;//删除访问Classes表的记录集指针
if (m_pSetD)
delete m_pSetD;//删除访问Deparment表的记录集指针
}
void CClassView::DoDataExchange(CDataExchange* pDX)
{
CRecordView::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CClassView)
DDX_Control(pDX, IDC_COMBO_DEPARTNAME, m_departmentname);
DDX_Control(pDX, IDC_BUTTON_MOVEPREV, m_moveprev);
DDX_Control(pDX, IDC_BUTTON_MOVENEXT, m_movenext);
DDX_Control(pDX, IDC_BUTTON_MOVELAST, m_movelast);
DDX_Control(pDX, IDC_BUTTON_MOVEFIRST, m_movefirst);
DDX_Text(pDX, IDC_EDIT_RECNEWS, m_recnews);
DDX_FieldText(pDX, IDC_EDIT_CLASSID, m_pSet->m_id, m_pSet);
DDX_FieldText(pDX, IDC_EDIT_CLASSNAME, m_pSet->m_name, m_pSet);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CClassView, CRecordView)
//{{AFX_MSG_MAP(CClassView)
ON_BN_CLICKED(IDC_SAVERECORD, OnSaverecord)
ON_BN_CLICKED(IDC_BUTTON_MOVEPREV, OnButtonMoveprev)
ON_BN_CLICKED(IDC_BUTTON_MOVENEXT, OnButtonMovenext)
ON_BN_CLICKED(IDC_BUTTON_MOVELAST, OnButtonMovelast)
ON_BN_CLICKED(IDC_BUTTON_MOVEFIRST, OnButtonMovefirst)
ON_BN_CLICKED(IDC_ADDNEWRECORD, OnAddnewrecord)
ON_BN_CLICKED(IDC_DELETERECORD, OnDeleterecord)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CClassView diagnostics
#ifdef _DEBUG
void CClassView::AssertValid() const
{
CRecordView::AssertValid();
}
void CClassView::Dump(CDumpContext& dc) const
{
CRecordView::Dump(dc);
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CClassView message handlers
CRecordset* CClassView::OnGetRecordset()
{
if (m_pSet != NULL)
return m_pSet;
m_pSet = new CClassSet(NULL);
m_pSet->Open();
m_pSetD = new CDepartmentSet(NULL);//创建访问Deparment表的记录集指针
m_pSetD->Open();//打开访问Deparment表的记录集
return m_pSet;
}
CClassSet* CClassView::GetRecordset()
{
CClassSet* pData = (CClassSet*) OnGetRecordset();
ASSERT(pData == NULL || pData->IsKindOf(RUNTIME_CLASS(CClassSet)));
return pData;
}
void CClassView::OnInitialUpdate()
{
BeginWaitCursor();
GetRecordset();
CRecordView::OnInitialUpdate();
GetDocument()->SetTitle("班级信息管理");//设置文档标题
GetParent()->SetWindowText("班级信息管理");//设置子窗口标题
if (!m_pSet->IsOpen())
m_pSet->Open();
if (!m_pSet->IsEOF())
{ //若记录集不为空,则遍历记录集,
//使GetRecordCount函数返回准确的记录数
while(!m_pSet->IsEOF())
m_pSet->MoveNext();
m_reccount=m_pSet->GetRecordCount();
m_pSet->MoveFirst();
m_recno=1;
}
//创建系部名称下拉列表
if (!m_pSetD->IsOpen())
m_pSetD->Open();
while(!m_pSetD->IsEOF())
{
if(CB_ERR==m_departmentname.FindString(-1,m_pSetD->m_name))
m_departmentname.AddString(m_pSetD->m_name);//不重复,加入列表
m_pSetD->MoveNext();
}
ShowData();//显示当前记录
EndWaitCursor();
}
void CClassView::OnSaverecord()
{
try{
if (m_recno>0)
{ //若有当前记录,则执行保存操作
m_pSet->Edit();//使当前记录进入编辑状态
UpdateData(true);//用窗体数据更新记录集id和name字段
//根据系部名称确定系部编号
CString str;
m_departmentname.GetWindowText(str);
m_pSetD->m_strFilter="name='" + str + "'";
m_pSetD->Requery();
m_pSet->m_departmentid=m_pSetD->m_id;//设置departmentid字段值
if (m_pSet->CanUpdate()) {
m_pSet->Update();//将记录集更新返回数据库
}
AfxMessageBox("成功保存数据!");
}
}
catch(CDBException* e) {
m_pSet->CancelUpdate();//撤销引起错误的操作
AfxMessageBox(e->m_strError);//显示错误信息
e->Delete();//删除错误对象
}
}
void CClassView::OnButtonMoveprev()
{ //使前一个记录成为当前记录
if (m_recno>1)
{
m_pSet->MovePrev();
m_recno--;
ShowData();//显示当前记录数据
}
}
void CClassView::OnButtonMovenext()
{ //使下一个记录成为当前记录
if (m_recno<m_reccount)
{
m_pSet->MoveNext();
m_recno++;
ShowData();//显示当前记录数据
}
}
void CClassView::OnButtonMovelast()
{ //使最后一个记录成为当前记录
if(m_recno<m_reccount)
{
m_pSet->MoveLast();
m_recno=m_reccount;
ShowData(); //显示当前记录数据
}
}
void CClassView::OnButtonMovefirst()
{ //使第一个记录成为当前记录
if(m_recno>1)
{
m_pSet->MoveFirst();
m_recno=1;
ShowData(); //显示当前记录数据
}
}
void CClassView::OnAddnewrecord()
{
try{
m_pSet->AddNew();
UpdateData(true);//用窗体数据更新记录集id和name字段
//根据系部名称确定系部编号
CString str;
m_departmentname.GetWindowText(str);
m_pSetD->m_strFilter="name='" + str + "'";
m_pSetD->Requery();
m_pSet->m_departmentid=m_pSetD->m_id;//设置departmentid字段值
if (m_pSet->CanUpdate()) {
m_pSet->Update();//将记录集更新返回数据库
m_reccount++;
}
m_recno=m_reccount;
m_pSet->MoveLast();
ShowData();
AfxMessageBox("成功添加记录!");
}
catch(CDBException* e) {
m_pSet->CancelUpdate();//撤销引起错误的操作
AfxMessageBox(e->m_strError);//显示错误信息
e->Delete();//删除错误对象
}
}
void CClassView::ShowData()
{
if (m_pSet->IsOpen())
{
if (m_recno>1)
{ //当前记录不是第一条记录,启用向前和第一条记录按钮
m_movefirst.EnableWindow(true);
m_moveprev.EnableWindow(true);
}
else
{ //当前记录是第一条记录,则禁用向前和第一条记录按钮
m_movefirst.EnableWindow(false);
m_moveprev.EnableWindow(false);
}
if (m_recno==m_reccount)
{ //当前记录是最后一条记录,禁用向后和最后一条记录按钮
m_movenext.EnableWindow(false);
m_movelast.EnableWindow(false);
}
else
{ if(m_recno>=0)
{ //若当前记录不是最后一条记录,则启用向后和最后一条记录按钮
m_movenext.EnableWindow(true);
m_movelast.EnableWindow(true);
}
}
//显示当前记录号和记录总数
CString str;
str.Format("%d/%d",m_recno,m_reccount);
m_recnews=str; //设置记录信息成员变量
//根据系部编号确定系部名称
m_pSetD->m_strFilter="id='" + m_pSet->m_departmentid + "'";
m_pSetD->Requery();
m_departmentname.SelectString(-1,m_pSetD->m_name);
UpdateData(false); //将成员变量数据传递到窗口
}
}
void CClassView::OnDeleterecord()
{
if (m_recno>0)
{ //若有当前记录,则执行删除操作
try {
m_pSet->Delete();//删除当前记录
}
catch(CDBException* e) {
m_pSet->CancelUpdate();//撤销引起错误的操作
//如果删除操作发生错误,则显示错误信息
AfxMessageBox(e->m_strError);//显示错误信息
e->Delete();//删除错误对象
m_pSet->MoveFirst(); //使第一条记录成为当前记录
m_recno=1;
ShowData();//刷新窗口
return;
}
if (m_recno==m_reccount) {
//如果删除的是最后一条记录,则使前一条记录成为当前记录
m_pSet->MovePrev();
m_recno--;
}
else {
m_pSet->MoveNext();//使下一条记录成为当前记录
}
m_reccount--;
ShowData();//显示新的当前记录数据
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -