📄 studentview.cpp
字号:
// StudentView.cpp : implementation file
//
#include "stdafx.h"
#include "TestApp.h"
#include "StudentView.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CStudentView
IMPLEMENT_DYNCREATE(CStudentView, CRecordView)
CStudentView::CStudentView()
: CRecordView(CStudentView::IDD)
{
//{{AFX_DATA_INIT(CStudentView)
m_pSet = NULL;
m_recnews = _T("");
m_recno=0;//初始化当前记录号
m_reccount=0;//初始化记录总数
//}}AFX_DATA_INIT
}
CStudentView::~CStudentView()
{
((CTestAppApp*)AfxGetApp())->m_StudentViews=0;//启用显示学生信息管理窗口菜单命令
if (m_pSet)
delete m_pSet;//删除访问Students表的记录集指针
if (m_pSetC)
delete m_pSetC;//删除访问Classes表的记录集指针
}
void CStudentView::DoDataExchange(CDataExchange* pDX)
{
CRecordView::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CStudentView)
DDX_Control(pDX, IDC_COMBO_CLASSNAME, m_classname);
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_ROOM, m_pSet->m_room, m_pSet);
DDV_MaxChars(pDX, m_pSet->m_room, 10);
DDX_FieldText(pDX, IDC_EDIT_STUDENTID, m_pSet->m_id, m_pSet);
DDV_MaxChars(pDX, m_pSet->m_id, 8);
DDX_FieldText(pDX, IDC_EDIT_STUNAME, m_pSet->m_name, m_pSet);
DDV_MaxChars(pDX, m_pSet->m_name, 15);
DDX_FieldText(pDX, IDC_EDIT_EXAMID, m_pSet->m_examid, m_pSet);
DDV_MaxChars(pDX, m_pSet->m_examid, 8);
DDX_FieldText(pDX, IDC_EDIT_TIME, m_pSet->m_time, m_pSet);
DDV_MaxChars(pDX, m_pSet->m_time, 18);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CStudentView, CRecordView)
//{{AFX_MSG_MAP(CStudentView)
ON_BN_CLICKED(IDC_ADDNEWRECORD, OnAddnewrecord)
ON_BN_CLICKED(IDC_BUTTON_MOVEFIRST, OnButtonMovefirst)
ON_BN_CLICKED(IDC_BUTTON_MOVELAST, OnButtonMovelast)
ON_BN_CLICKED(IDC_BUTTON_MOVENEXT, OnButtonMovenext)
ON_BN_CLICKED(IDC_BUTTON_MOVEPREV, OnButtonMoveprev)
ON_BN_CLICKED(IDC_DELETERECORD, OnDeleterecord)
ON_BN_CLICKED(IDC_SAVERECORD, OnSaverecord)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CStudentView diagnostics
#ifdef _DEBUG
void CStudentView::AssertValid() const
{
CRecordView::AssertValid();
}
void CStudentView::Dump(CDumpContext& dc) const
{
CRecordView::Dump(dc);
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CStudentView message handlers
CRecordset* CStudentView::OnGetRecordset()
{
if (m_pSet != NULL)
return m_pSet;
m_pSet = new CStudentSet(NULL);
m_pSet->Open();
m_pSetC = new CClassSet(NULL);//创建访问Classes表的记录集指针
m_pSetC->Open();//打开访问Classes表的记录集
return m_pSet;
}
CStudentSet* CStudentView::GetRecordset()
{
CStudentSet* pData = (CStudentSet*) OnGetRecordset();
ASSERT(pData == NULL || pData->IsKindOf(RUNTIME_CLASS(CStudentSet)));
return pData;
}
void CStudentView::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_pSetC->IsOpen())
m_pSetC->Open();
while(!m_pSetC->IsEOF())
{
if(CB_ERR==m_classname.FindString(-1,m_pSetC->m_name))
m_classname.AddString(m_pSetC->m_name);//不重复,加入列表
m_pSetC->MoveNext();
}
ShowData();//显示当前记录
EndWaitCursor();
}
void CStudentView::OnAddnewrecord()
{
try{
m_pSet->AddNew();
UpdateData(true);//用窗体数据更新记录集绑定字段
//根据班级名称确定班级编号
CString str;
m_classname.GetWindowText(str);
m_pSetC->m_strFilter="name='" + str + "'";
m_pSetC->Requery();
m_pSet->m_classid=m_pSetC->m_id;//设置classid字段值
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 CStudentView::OnButtonMovefirst()
{ //使第一个记录成为当前记录
if(m_recno>1)
{
m_pSet->MoveFirst();
m_recno=1;
ShowData(); //显示当前记录数据
}
}
void CStudentView::OnButtonMovelast()
{ //使最后一个记录成为当前记录
if(m_recno<m_reccount)
{
m_pSet->MoveLast();
m_recno=m_reccount;
ShowData(); //显示当前记录数据
}
}
void CStudentView::OnButtonMovenext()
{
//使下一个记录成为当前记录
if (m_recno<m_reccount)
{
m_pSet->MoveNext();
m_recno++;
ShowData();//显示当前记录数据
}
}
void CStudentView::OnButtonMoveprev()
{ //使前一个记录成为当前记录
if (m_recno>1)
{
m_pSet->MovePrev();
m_recno--;
ShowData();//显示当前记录数据
}
}
void CStudentView::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();//显示新的当前记录数据
AfxMessageBox("成功删除记录!");
}
}
void CStudentView::OnSaverecord()
{
try{
if (m_recno>0)
{ //若有当前记录,则执行保存操作
m_pSet->Edit();//使当前记录进入编辑状态
UpdateData(true);//用窗体数据更新记录集绑定字段
//根据班级名称确定班级编号
CString str;
m_classname.GetWindowText(str);
m_pSetC->m_strFilter="name='" + str + "'";
m_pSetC->Requery();
m_pSet->m_classid=m_pSetC->m_id;//设置classid字段值
if (m_pSet->CanUpdate()) {
m_pSet->Update();//将记录集更新返回数据库
}
AfxMessageBox("成功保存数据!");
}
}
catch(CDBException* e) {
m_pSet->CancelUpdate();//撤销引起错误的操作
AfxMessageBox(e->m_strError);//显示错误信息
e->Delete();//删除错误对象
}
}
void CStudentView::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_pSetC->m_strFilter="id='" + m_pSet->m_classid + "'";
m_pSetC->Requery();
m_classname.SelectString(-1,m_pSetC->m_name);
UpdateData(false); //将成员变量数据传递到窗口
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -