【VC开源代码栏目提醒】:网学会员,鉴于大家对VC开源代码十分关注,论文会员在此为大家搜集整理了“DPersonnel.cpp”一文,供大家参考学习!
// DPersonnel.cpp : implementation file
//
#include "stdafx.h"
#include "qpglxt.h"
#include "DPersonnel.h"
#include "DBaseQuery.h"
#include "externDllHeader.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CDPersonnel dialog
CDPersonnel::CDPersonnel(CWnd* pParent /*=NULL*/)
: CDialog(CDPersonnel::IDD, pParent)
{
//{{AFX_DATA_INIT(CDPersonnel)
//}}AFX_DATA_INIT
}
void CDPersonnel::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDPersonnel)
DDX_Control(pDX, IDC_SPXX_BUTUNDO, m_ButUndo);
DDX_Control(pDX, IDC_SPXX_BUTSAVE, m_ButSave);
DDX_Control(pDX, IDC_SPXX_BUTEXIT, m_ButExit);
DDX_Control(pDX, IDC_SPXX_BUTDELE, m_ButDele);
DDX_Control(pDX, IDC_SPXX_BUTCHANGE, m_ButChange);
DDX_Control(pDX, IDC_PERSONNEL_EDTID, m_EdtID);
DDX_Control(pDX, IDC_SPXX_BUTADD, m_ButAdd);
DDX_Control(pDX, DC_PERSONNEL_EDTSTIPEND, m_EdtStipend);
DDX_Control(pDX, DC_PERSONNEL_EDTNAME, m_EdtName);
DDX_Control(pDX, DC_PERSONNEL_EDTMEM, m_EdtMem);
DDX_Control(pDX, DC_PERSONNEL_EDTDUTY, m_EdtDuty);
DDX_Control(pDX, DC_PERSONNEL_DTDATE, m_DtDate);
DDX_Control(pDX, DC_PERSONNEL_COMSEX, m_ComSex);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CDPersonnel, CDialog)
//{{AFX_MSG_MAP(CDPersonnel)
ON_BN_CLICKED(IDC_SPXX_BUTADD, OnSpxxButadd)
ON_BN_CLICKED(IDC_SPXX_BUTCHANGE, OnSpxxButchange)
ON_BN_CLICKED(IDC_SPXX_BUTDELE, OnSpxxButdele)
ON_BN_CLICKED(IDC_SPXX_BUTSAVE, OnSpxxButsave)
ON_BN_CLICKED(IDC_SPXX_BUTUNDO, OnSpxxButundo)
ON_BN_CLICKED(IDC_SPXX_BUTEXIT, OnSpxxButexit)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CDPersonnel message handlers
void CDPersonnel::Clear()
{
m_EdtID.SetWindowText("");
m_EdtStipend.SetWindowText("");
m_EdtName.SetWindowText("");
m_EdtMem.SetWindowText("");
m_EdtDuty.SetWindowText("");
CTime time;
time=time.GetCurrentTime();
m_DtDate.SetTime(&time);
m_ComSex.SetCurSel(0);
}
void CDPersonnel::Display(CString ID)
{
RxRecordset Drxt;
CString sSQL;
if(ID.IsEmpty())
return;
sSQL.Format("SELECT * FROM 员工信息表 WHERE 编号 =%s",ID);
Drxt.Open(sSQL,adCmdText);
CString sID,sName,sSex,sDuty,sDate,sStipend,sMem;
sID=Drxt.GetFieldValue("编号");
sName=Drxt.GetFieldValue("");
sSex=Drxt.GetFieldValue("性别");
sDuty=Drxt.GetFieldValue("职务");
sDate=Drxt.GetFieldValue("聘用日期");
sStipend=Drxt.GetFieldValue("薪金");
sMem=Drxt.GetFieldValue("备注");
m_EdtID.SetWindowText(sID);
m_EdtStipend.SetWindowText(sStipend);
m_EdtName.SetWindowText(sName);
m_EdtMem.SetWindowText(sMem);
m_EdtDuty.SetWindowText(sDuty);
CTime time;
time=CStringTOCTime(sDate);
m_DtDate.SetTime(&time);
m_ComSex.SetWindowText(sSex);
}
void CDPersonnel::Enabled(bool bEnabled)
{
m_EdtStipend.EnableWindow(bEnabled);
m_EdtName.EnableWindow(bEnabled);
m_EdtMem.EnableWindow(bEnabled);
m_EdtDuty.EnableWindow(bEnabled);
m_DtDate.EnableWindow(bEnabled);
m_ComSex.EnableWindow(bEnabled);
m_ButUndo.EnableWindow(bEnabled);
m_ButSave.EnableWindow(bEnabled);
m_ButExit.EnableWindow(!bEnabled);
m_ButDele.EnableWindow(!bEnabled);
m_ButChange.EnableWindow(!bEnabled);
m_ButAdd.EnableWindow(!bEnabled);
}
void CDPersonnel::OnSpxxButadd()
{
AddOrChange=1;
CString sNewID;
sNewID=ado.AutoNumber("员工信息表","编号","",1);
this->Clear();
m_EdtID.SetWindowText(sNewID);
this->Enabled(true);
this->m_EdtName.SetFocus();
}
void CDPersonnel::OnSpxxButchange()
{
AddOrChange=2;
this->Enabled(true);
this->m_EdtName.SetFocus();
}
void CDPersonnel::OnSpxxButdele()
{
if(MessageBox("确定要删除记录吗?"," 系统提示",MB_OKCANCEL|MB_ICONQUESTION)!=1)
return;
CString cID,sSQL;
this->m_EdtID.GetWindowText(cID);
sSQL.Format("DELETE FROM 员工信息表 WHERE 编号=%s",cID);
rst.Open(sSQL,adCmdText);
this->OnCancel();
}
void CDPersonnel::OnSpxxButsave()
{
if(MessageBox("确定要保存记录吗?"," 系统提示",MB_OKCANCEL|MB_ICONQUESTION)!=1)
return;
CString sSQL,sID,sName,sSex,sDuty,sDate,sStipend,sMem;
m_EdtID.GetWindowText(sID);
m_EdtStipend.GetWindowText(sStipend);
m_EdtName.GetWindowText(sName);
m_EdtMem.GetWindowText(sMem);
m_EdtDuty.GetWindowText(sDuty);
CTime time;
m_DtDate.GetTime(time);
sDate=CTimeToCString(time);
m_ComSex.GetWindowText(sSex);
if(this->AddOrChange==1)//添加
sSQL.Format("INSERT INTO 员工信息表 VALUES(%s,'%s','%s','%s',#%s#,%s,'%s')",sID,sName,sSex,sDuty,sDate,sStipend,sMem);
else//修改
sSQL.Format("UPDATE 员工信息表 SET ='%s',性别='%s',职务='%s',聘用日期=#%s#,薪金=%s,备注='%s' WHERE 编号=%s",sName,sSex,sDuty,sDate,sStipend,sMem,sID);
rst.Open(sSQL,adCmdText);
this->Enabled(false);
this->AddOrChange=0;
}
void CDPersonnel::OnSpxxButundo()
{
if(MessageBox("确定要撤消操作吗?"," 系统提示",MB_OKCANCEL|MB_ICONQUESTION)!=1)
return;
this->Enabled(false);
this->Clear();
this->Display(m_sID);
}
void CDPersonnel::OnSpxxButexit()
{
this->OnCancel();
}
BOOL CDPersonnel::OnInitDialog()
{
CDialog::OnInitDialog();
CDBaseQuery* Parent =(CDBaseQuery*)this->FindWindow(NULL,"员工信息查询");
CString sSQL,sID;
sID=Parent->m_Grid.GetItemText(Parent->m_CurrentRow,0);
m_sID=sID;
this->Display(sID);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
上一篇:
downonline.cpp
下一篇:
浮生若萍