📄 teachmdlg.cpp
字号:
// TeachMdlg.cpp : implementation file
//
#include "stdafx.h"
#include "Student.h"
#include "TeachMdlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CTeachMdlg dialog
CTeachMdlg::CTeachMdlg(CWnd* pParent /*=NULL*/)
: CDialog(CTeachMdlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CTeachMdlg)
m_phone = _T("");
m_post = _T("");
m_teacher = _T("");
m_name = _T("");
m_college = _T("");
m_depart = _T("");
//}}AFX_DATA_INIT
}
void CTeachMdlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CTeachMdlg)
DDX_Control(pDX, IDC_COMBO_SEX, m_combosex);
DDX_Text(pDX, IDC_EDIT_PHONE, m_phone);
DDV_MaxChars(pDX, m_phone, 30);
DDX_Text(pDX, IDC_EDIT_POST, m_post);
DDV_MaxChars(pDX, m_post, 1);
DDX_Text(pDX, IDC_EDIT_TEACH_NO, m_teacher);
DDX_Text(pDX, IDC_EDIT_NAME, m_name);
DDV_MaxChars(pDX, m_name, 12);
DDX_Text(pDX, IDC_EDIT_COLL_NO, m_college);
DDV_MaxChars(pDX, m_college, 2);
DDX_Text(pDX, IDC_EDIT_DEPART_NO, m_depart);
DDV_MaxChars(pDX, m_depart, 4);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CTeachMdlg, CDialog)
//{{AFX_MSG_MAP(CTeachMdlg)
ON_BN_CLICKED(IDC_BTN_NEXTI, OnBtnNexti)
ON_BN_CLICKED(IDC_BTN_PREV, OnBtnPrev)
ON_BN_CLICKED(IDC_BTN_RETURN, OnBtnReturn)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CTeachMdlg message handlers
void CTeachMdlg::OnBtnNexti()
{
// TODO: Add your control notification handler code here
m_pTeacher->MoveNext();
if(m_pTeacher->IsEOF())
m_pTeacher->MoveLast();
UpdateField(FALSE);
}
void CTeachMdlg::OnBtnPrev()
{
// TODO: Add your control notification handler code here
m_pTeacher->MovePrev();
UpdateField(FALSE);
}
void CTeachMdlg::OnBtnReturn()
{
// TODO: Add your control notification handler code here
UpdateField(FALSE);
}
void CTeachMdlg::OnCancel()
{
// TODO: Add extra cleanup here
CDialog::OnCancel();
}
void CTeachMdlg::OnOK()
{
// TODO: Add extra validation here
// TODO: Add your control notification handler code here
CModifydlg modify;
int result=modify.DoModal();
if(result == IDCANCEL)
return;
if(m_kind == 1)//教师
UpdateField(true);
else MessageBox("你无权修改数据!");
CDialog::OnOK();
}
BOOL CTeachMdlg::OnInitDialog()
{
CString strSQL;
BOOL Success;
CTeacherSet rs;
//CDialog::OnInitDialog();
// TODO: Add extra initialization here
try{
strSQL="select Teacher_no,Name,Sex,Phone,Post,College_no,Depart_no from Teacher";
Success=rs.Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);
if(!Success)
{
MessageBox("教师表打开失败!");
this->OnCancel();
return TRUE;
}
UpdateField(FALSE);
rs.Close();
}
catch(CDBException *pe){
AfxMessageBox(pe->m_strError);
pe->Delete();
}
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CTeachMdlg::UpdateField(BOOL bSave)
{
CString strTemp;
CString strExpress,strSQL,strField;
if(bSave)
{
this->UpdateData(true);
//m_name.TrimRight();
strExpress.Format("name=\'%s\'",m_name);
strSQL="update group1.Class set "+strExpress;
strExpress.Format("Teacher_no=\'%s\'",m_teacher);
strSQL+=","+strExpress;
strExpress.Format("sex=\'%d\'",m_combosex.GetCurSel()+1);
strSQL+=","+strExpress;
strExpress.Format("Phone=\'%s\'",m_phone);
strSQL+=","+strExpress;
strExpress.Format("Post=\'%s\'",m_post);
strSQL+=","+strExpress;
strExpress.Format("College_no=\'%s\'",m_college);
strSQL+=","+strExpress;
strExpress.Format("Depart_no=\'%s\'",m_depart);
strSQL+=","+strExpress;
m_pDB->ExecuteSQL(strSQL);
m_pTeacher->Requery();
UpdateField(FALSE);
}
else
{
m_pTeacher->GetFieldValue("NAME",m_name);
m_pTeacher->GetFieldValue("TEACHER_NO",m_teacher);
m_pTeacher->GetFieldValue("SEX",strTemp);
m_combosex.SetCurSel(atoi(strTemp)-1);
m_pTeacher->GetFieldValue("POST",m_post);
m_pTeacher->GetFieldValue("COLEGE_NO",m_college);
m_pTeacher->GetFieldValue("DEPART_NO",m_depart);
this->UpdateData(bSave);
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -