1、 “工资管理系统”设计内容 成员:XXX、XXX、XXX、XXX、XXX、XXX、XXX 一、系统功能分析 本系统要求实现以下主要功能: 1.数据基本管理功能 主要任务是对各种工资信息进行日常的管理,如: (1)工资信息的输入 (2)数据的修改 (3)数据的增加、删除 2.数据查询功能 系统需要提供以下查询功能: (1)员工基本信息情况查询: 员工姓名,员工号,身份证号,职称,身份证号,银行卡号,电话 (2)员工月工资情况查询: 员工号,姓名,部门名,基本工资,各种扣款,加班费,应得工资 (3)职称基本信息情况查询: 职称
2、名称,职称基本工资 二、系统设计的功能模块 三、E-R图设计 四、需要建立的库和表 1、建立“工资管理系统”数据库 2、建立四张表 (1)员工基本信息表 (2)基本工资表 (3)职称工资表 (4)用户表 五、程序和主要实现界面 1、程序 (1)界面 // StaffSystermView.cpp : implementation of the CStaffSystermView class // #include "stdafx.h" #include "StaffSysterm.h" #include
3、"StaffSystermDoc.h" #include "StaffSystermView.h" #include "afxdb.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif #define WM_INSERT 2000 #define WM_DELETE 2001 #define WM_ADDOVERTIME 3000 #define WM_ADDPRIZE 3001 #define WM_CANCELPRI
4、ZE 3002 #define WM_ADDLATE 3003 #define WM_WAGETOTAL 3004 #define WM_CLEARPWAGE 3005 #define WM_CLEARWAGE 3006 /////////////////////////////////////////// // CStaffSystermView IMPLEMENT_DYNCREATE(CStaffSystermView, CFormView) BEGIN_MESSAGE_MAP(CStaffSystermView, CFormView) //{{AFX_MSG_M
5、AP(CStaffSystermView) ON_COMMAND(IDM_SHOWTAFF, OnShowtaff) ON_COMMAND(IDM_STAFFWAGE, OnStaffwage) ON_COMMAND(IDM_ADDSTAFF, OnAddstaff) ON_COMMAND(IDM_DELETESTAFF, OnDeletestaff) ON_COMMAND(IDM_LATEADD, OnLateadd) ON_COMMAND(IDM_PRIZE, OnPrize) ON_COMMAND(IDM_TOTAL, OnTotal) ON_COMMAND(IDM_C
6、LEARPRIZE, OnClearprize) ON_COMMAND(IDM_CLEARSWAGE, OnClearswage) ON_COMMAND(IDM_CLEARWAGE, OnClearwage) ON_COMMAND(IDM_OVERTIMEWAGE, OnOvertimewage) ON_NOTIFY(NM_RCLICK, IDC_LIST1, OnRclickList1) ON_COMMAND(ID_BUTTON32791, OnButton32791) ON_COMMAND(ID_BUTTON32792, OnButton32792) ON_CO
7、MMAND(ID_BUTTON32794, OnButton32794) ON_COMMAND(ID_BUTTON32795, OnButton32795) ON_COMMAND(ID_BUTTON32796, OnButton32796) ON_COMMAND(ID_BUTTON32797, OnButton32797) ON_COMMAND(ID_BUTTON32798, OnButton32798) ON_BN_CLICKED(IDC_BTN_FIND, OnBtnFind) ON_COMMAND(ID_BUTTON32800_SHOWSTAFF, OnButto
8、n32800Showstaff) ON_COMMAND(ID_BUTTON32804_SHOWWAGE, OnButton32804Showwage) ON_COMMAND(ID_BUTTON32805_PRINTVIEW, OnButton32805Printview) ON_COMMAND(IDM_UPDATAZCWAGE, OnUpdatazcwage) ON_COMMAND(IDM_ADDZC, OnAddzc) ON_COMMAND(IDM_SHOWZC, OnShowzc) ON_COMMAND(ID_BUTTON32809_ZC, OnButton3280
9、9Zc) ON_COMMAND(WM_INSERT,OnAddstaff) ON_COMMAND(WM_DELETE,OnDeletestaff) ON_COMMAND(WM_ADDOVERTIME,OnOvertimewage) ON_COMMAND(WM_ADDPRIZE,OnPrize) ON_COMMAND(WM_CANCELPRIZE,OnClearprize) ON_COMMAND(WM_ADDLATE,OnLateadd) ON_COMMAND(WM_WAGETOTAL,OnTotal) ON_COMMAND(WM_CLEARPWAGE,OnClearswage)
10、 ON_COMMAND(WM_CLEARWAGE,OnClearwage) ON_COMMAND(IDM_SAVEDATABASE, OnSavedatabase) ON_COMMAND(IDM_RESTORE, OnRestore) //}}AFX_MSG_MAP // Standard printing commands ON_COMMAND(ID_FILE_PRINT, CFormView::OnFilePrint) ON_COMMAND(ID_FILE_PRINT_DIRECT, CFormView::OnFilePrint) ON_COMMAND(ID_FILE
11、PRINT_PREVIEW, CFormView::OnFilePrintPreview) END_MESSAGE_MAP() ///////////////////////////////// CStaffSystermView construction/destruction CStaffSystermView::CStaffSystermView() : CFormView(CStaffSystermView::IDD) { //{{AFX_DATA_INIT(CStaffSystermView) //}}AFX_DATA_INIT // TODO: add
12、 construction code here m_login.DoModal(); pDb=new CDatabase(); } CStaffSystermView::~CStaffSystermView() { } void CStaffSystermView::DoDataExchange(CDataExchange* pDX) { CFormView::DoDataExchange(pDX); //{{AFX_DATA_MAP(CStaffSystermView) DDX_Control(pDX, IDC_COMBO_FIND, m_
13、ControlComFind); DDX_Control(pDX, IDC_LIST2, m_findTemp); DDX_Control(pDX, IDC_LIST1, m_DataArea); //}}AFX_DATA_MAP } BOOL CStaffSystermView::PreCreateWindow(CREATESTRUCT& cs) { // TODO: Modify the Window class or styles here by modifying // the CREATESTRUCT cs return CFormView:
14、PreCreateWindow(cs); } void CStaffSystermView::OnInitialUpdate() { CFormView::OnInitialUpdate(); GetParentFrame()->RecalcLayout(); ResizeParentToFit(); m_DataArea.SetExtendedStyle( LVS_EX_FLATSB //扁平风格滚动条 |LVS_EX_FULLROWSELECT //允许整行选中 |LVS_EX_HEADERDRAGDROP //
15、允许标题拖拽 |LVS_EX_ONECLICKACTIVATE //高亮显示 |LVS_EX_GRIDLINES //画出网格线 ); m_findTemp.SetExtendedStyle( LVS_EX_FLATSB //扁平风格滚动条 |LVS_EX_FULLROWSELECT //允许整行选中 |LVS_EX_HEADERDRAGDROP //允许标题拖拽 |LVS_EX_ONECLICKACTIVATE //高亮显示 |LVS_EX_GRIDLINES //画出网格线
16、 ); m_ControlComFind.AddString("员工号"); m_ControlComFind.AddString("员工姓名"); SetDlgItemText(IDC_COMBO_FIND,"员工号"); } ///////////////////////////////////////// // CStaffSystermView printing BOOL CStaffSystermView::OnPreparePrinting(CPrintInfo* pInfo) { // default preparation return D
17、oPreparePrinting(pInfo); } void CStaffSystermView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/) { // TODO: add extra initialization before printing } void CStaffSystermView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/) { // TODO: add cleanup after printing } void CSta
18、ffSystermView::OnPrint(CDC* pDC, CPrintInfo* /*pInfo*/) { // TODO: add customized printing code here } /////////////////////////////////////////// // CStaffSystermView diagnostics #ifdef _DEBUG void CStaffSystermView::AssertValid() const { CFormView::AssertValid(); } void CStaffSyst
19、ermView::Dump(CDumpContext& dc) const { CFormView::Dump(dc); } CStaffSystermDoc* CStaffSystermView::GetDocument() // non-debug version is inline { ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CStaffSystermDoc))); return (CStaffSystermDoc*)m_pDocument; } #endif //_DEBUG /////////////////
20、///////////////////// // CStaffSystermView message handlers void CStaffSystermView::ShowStaffTable() { m_tableNum=1; clearColumn(); setColumn("员工基本信息表"); pDb->Open(NULL,FALSE,FALSE,"ODBC;DSN=pubSQL;UID=sqlc;PWD=",FALSE); //xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx// CString strsql="s
21、elect * from 员工基本信息表";
rs.m_pDatabase=pDb;
rs.Open(CRecordset::forwardOnly,strsql);
try
{
int index=0;
CString s[10];
CString t;
short n=rs.GetODBCFieldCount();
while (!rs.IsEOF())
{
t="";
for (short i=0;i 22、i].TrimRight(" ");
t+=s[i];
}
///////////////////////////////////////////
int nRow=m_DataArea.InsertItem(index, s[0]); //插入行
m_DataArea.SetItemText(index,1,s[1]); //设置数据
m_DataArea.SetItemText(index,2,s[2]); //设置数据
m_DataArea.SetItemText(index,3,s[3]); //设置数据
m_DataArea.SetItemT 23、ext(index,4,s[4]); //设置数据
m_DataArea.SetItemText(index,5,s[5]); //设置数据
m_DataArea.SetItemText(index,6,s[6]); //设置数据
m_DataArea.SetItemText(index,7,s[7]); //设置数据
index++;
///////////////////////////////////////
rs.MoveNext();
}
rs.Close();
pDb->Close();
}
catch (CD 24、BException *pEx) {
pDb->Close();
rs.Close();
pEx->ReportError();
}
}
void CStaffSystermView::OnShowtaff()
{
// TODO: Add your command handler code here
ShowStaffTable();
}
void CStaffSystermView::OnStaffwage()
{
// TODO: Add your command handler code here
ShowWageTable 25、);
}
void CStaffSystermView::clearColumn()
{
m_DataArea.DeleteAllItems();
int n=m_DataArea.GetHeaderCtrl()->GetItemCount();
for (int i=0;i 26、
pDb->Open(NULL,FALSE,FALSE,"ODBC;DSN=pubSQL;UID=sql;PWD=",FALSE);
//xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx//
CString strsql="select * from 基本工资表";
rs.m_pDatabase=pDb;
rs.Open(CRecordset::forwardOnly,strsql);
try
{
int index=0;
CString s[10];
CString t;
short n=rs.G 27、etODBCFieldCount();
while (!rs.IsEOF())
{
t="";
for (short i=0;i 28、dex,1,s[1]); //设置数据
m_DataArea.SetItemText(index,2,s[2]); //设置数据
m_DataArea.SetItemText(index,3,s[3]); //设置数据
m_DataArea.SetItemText(index,4,s[4]); //设置数据
m_DataArea.SetItemText(index,5,s[5]); //设置数据
m_DataArea.SetItemText(index,6,s[6]); //设置数据
m_DataArea.SetItemText(index,7,s[7]); / 29、/设置数据
index++;
///////////////////////////////////
rs.MoveNext();
}
rs.Close();
pDb->Close();
}
catch (CDBException *pEx) {
rs.Close();
pDb->Close();
pEx->ReportError();
}
}
void CStaffSystermView::OnAddstaff()
{
// TODO: Add your command handler co 30、de here
if(m_tableNum!=1)
{
AfxMessageBox("请先进入员工基本信息表!");
return;
}
m_addstaff.getArea(&m_DataArea);
m_addstaff.DoModal();
}
void CStaffSystermView::OnDeletestaff()
{
// TODO: Add your command handler code here
deletdTable("员工基本信息表");
}
void CStaffSystermView::setCo 31、lumn(CString tablename)
{
/* CDatabase *pDb=new CDatabase;*/
pDb->Open(NULL,FALSE,FALSE,"ODBC;DSN=pubSQL;UID=sql;PWD=",FALSE);
rs.m_pDatabase=pDb;
CODBCFieldInfo info;
CString strSQL=tablename;
// m_combTable.GetLBText(m_combTable.GetCurSel(), strSQL);
strSQL = _T("SELECT * FROM 32、 ") + strSQL;
rs.Open(CRecordset::forwardOnly,strSQL);
int nColumns = rs.GetODBCFieldCount();
for (int nNum = 0; nNum < nColumns; nNum++)
{
rs.GetODBCFieldInfo(nNum, info);
m_DataArea.InsertColumn(nNum, info.m_strName, LVCFMT_LEFT, 80);
if (nNum==0) {
firstColum=info.m_strName;
33、
}
}
pDb->Close();
}
void CStaffSystermView::OnLateadd()
{
// TODO: Add your command handler code here
if(m_tableNum!=2)
{
AfxMessageBox("请先进入基本工资表!");
return;
}
int index=m_DataArea.GetSelectionMark();
if (index<0) {
AfxMessageBox("请选择一条记录!");
pDb->Close();
34、 return;
}
pDb->Open(NULL,FALSE,FALSE,"ODBC;DSN=pubSQL;UID=sql;PWD=",FALSE);
CString id;
CString klate;
char m[10];
id=m_DataArea.GetItemText(index,0);
m_DataArea.GetItemText(index,5,m,10);
int lateN=atoi(m);
lateN++;
klate.Format("%d",lateN);
CString strsql;
//xxxxxxxxxxxxxxx 35、xxxxxxxxxxxxxxxxxxx//
strsql.Format("update 基本工资表 set 迟到次数=%d where 员工号='%s'",lateN,id);
try{
pDb->ExecuteSQL(strsql);
pDb->Close();
AfxMessageBox("已修改!");
m_DataArea.SetItemText(index,5,klate);
}
catch (CDBException *pEx)
{
pEx->ReportError();
}
pDb->Close() 36、
}
void CStaffSystermView::OnPrize()
{
// TODO: Add your command handler code here
if(m_tableNum!=2)
{
AfxMessageBox("请先进入基本工资表!");
return;
}
int index=m_DataArea.GetSelectionMark();
if(index<0)
{
AfxMessageBox("请选择一条记录!");
pDb->Close();
return;
}
m_prize.getA 37、rea(&m_DataArea);
m_prize.DoModal();
}
void CStaffSystermView::OnTotal()
{
// TODO: Add your command handler code here
if(m_tableNum!=2)
{
AfxMessageBox("请先进入基本工资表!");
return;
}
int index=0;
int countNum=m_DataArea.GetItemCount();
if(countNum==0)
{
AfxMessageBox("无记录 38、");
return;
}
CString id;
char basicWage[10],overtimeWage[10],prizeWage[10],lateNum[10],sj[10];
int total=0;
int part;
pDb->Open("pubSQL");
for(int i=0;i 39、etListText(index,3,overtimeWage);
total+=part;
part=getListText(index,4,prizeWage);
total+=part;
part=getListText(index,5,lateNum);
total=total-(part*50);
part=getListText(index,6,sj);
total=total-part;
//xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx///
CString strsql;
strsql.Form 40、at("update 基本工资表 set 应得工资=%d where 员工号='%s'",total,id);
try{
pDb->ExecuteSQL(strsql);
CString klate;
klate.Format("%d",total);
m_DataArea.SetItemText(index,7,klate);
}
catch (CDBException *pEx)
{
pDb->Close();
pEx->ReportError();
}
inde 41、x++;
total=0;
part=0;
}
AfxMessageBox("已完成!");
pDb->Close();
}
int CStaffSystermView::getListText(int index, int i, char *p)
{
m_DataArea.GetItemText(index,i,p,10);
int part=atoi(p);
return part;
}
void CStaffSystermView::OnClearprize()
{
// TODO: Add your command h 42、andler code here
if(m_tableNum!=2)
{
AfxMessageBox("请先进入基本工资表!");
return;
}
pDb->Open(NULL,FALSE,FALSE,"ODBC;DSN=pubSQL;UID=sql;PWD=",FALSE);
CString id;
int index=m_DataArea.GetSelectionMark();
id=m_DataArea.GetItemText(index,0);
CString strsql;
//xxxxxxxxxxxxxxxxxxxxxxxxxxxx 43、xxxxxxxxxxx//
strsql.Format("update 基本工资表 set 奖金=%d where 员工号='%s'",0,id);
try{
pDb->ExecuteSQL(strsql);
pDb->Close();
AfxMessageBox("已修改!");
m_DataArea.SetItemText(index,4,"0");
}
catch (CDBException *pEx)
{
pEx->ReportError();
}
pDb->Close();
}
void CStaff 44、SystermView::OnClearswage()
{
// TODO: Add your command handler code here
if(m_tableNum!=2)
{
AfxMessageBox("请先进入基本工资表!");
return;
}
int index=m_DataArea.GetSelectionMark();
if(index<0)
{
AfxMessageBox("请选择员工!");
return;
}
//xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx//
CSt 45、ring strsql="select * from 基本工资表";
CString id,name,wageS,wageJ;
int basicWage;
id=m_DataArea.GetItemText(index,0);
name=m_DataArea.GetItemText(index,1);
basicWage=getZCwage(id);
int sj=basicWage/100;
wageS.Format("%d",basicWage);
wageJ.Format("%d",sj);
CString insql1;
//xxxxxxxxxx 46、xxxxxxxxxxxxxxxxxxxxxxxxx//
insql1.Format("update 基本工资表 set 基本工资=%d,加班费=0,奖金=0,迟到次数=0,税金=%d,应得工资=0 where 员工号='%s'",basicWage,sj,id);
try
{
pDb->Open("pubSQL");
pDb->ExecuteSQL(insql1);
AfxMessageBox("已结算!");
m_DataArea.SetItemText(index,2,wageS);
m_DataArea.SetItemText(inde 47、x,3,"0");
m_DataArea.SetItemText(index,4,"0");
m_DataArea.SetItemText(index,5,"0");
m_DataArea.SetItemText(index,6,wageJ);
m_DataArea.SetItemText(index,7,"0");
pDb->Close();
}
catch (CDBException *pEx) {
pDb->Close();
pEx->ReportError();
}
pDb->Close();
}
void CStaffSyste 48、rmView::OnClearwage()
{
// TODO: Add your command handler code here
if(m_tableNum!=2)
{
AfxMessageBox("请先进入基本工资表!");
return;
}
int index=0;
int num=m_DataArea.GetItemCount();
for(int i=0;i 50、xxxx//
insql1.Format("update 基本工资表 set 基本工资=%d,加班费=0,奖金=0,迟到次数=0,税金=%d,应得工资=0 where 员工号='%s'",basicWage,sj,id);
try
{
pDb->Open("pubSQL");
pDb->ExecuteSQL(insql1);
m_DataArea.SetItemText(index,2,wageS);
m_DataArea.SetItemText(index,3,"0");
m_DataArea.SetItemText(index,






