ImageVerifierCode 换一换
格式:DOCX , 页数:29 ,大小:392.63KB ,
资源ID:6428145      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6428145.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(工资管理系统设计与开发本科学位论文.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

工资管理系统设计与开发本科学位论文.docx

1、工资管理系统设计与开发本科学位论文目录工资管理系统目录摘要0 引言1 系统需求分析2 总体设计1 项目规划2 系统功能结构3 设计目标3 系统设计1 开发及运行环境2 数据库设计4 主要功能模块设计1 建立工程框架2 封装数据库3 主窗口设计4 登录模块设计5 员工录入模块设计6 总体查询模块设计7 员工工资添加模块设计8 用户管理模块设计附录A 参考文献附录B 数据表摘要【摘要】随着我国国民经济建设的蓬勃发展和具有中国特色的社会主义市场经济体制的迅速完善,各个行业都在积极使用现代化的管理工具,不断改善企业的服务质量,提高工作效率。无论是行政职能,还是生产运作的管理要求的不断提高,在很大程度上

2、使企业不得不改变传统的经营管理方式以适应快速发展的社会主义市场经济,改变企业管理方式、方法已经成为企业发展的先决条件。建设一个科学高效的信息管理系统是解决这一问题的必由之路。对企业内部的财务运用现代化技术进行管理,是提高工作效率的有效手段。工资管理作为企业内部财务管理的一个重要方面,也逐步被企业管理者所重视,由于企业的规模的不断扩,大企业职工人数的不断增多,使工资发放成为企业管理中的一个重课题;再加上每一位职工的具体实际情况相同,规章章制度的不断完善,增大了个人工资发放难度;每个人每月的工资都要通过工资制度的审核,这大大增加了管理人员的工作量,通过计算机管理系统对员工工资进行全面的统计与管理,

3、全面解决了工资管理过程中所遇到的各种问题,并且克服了传统管理方式中的易出错等问题。工资管理系统成为企业现代化管理中的首选管理工具。【关键词】工资管理系统0 引言传统的工资管理方法,都是通过人工统计和计算的管理方式进行的。这样的管理方法不但费时费力,也容易产生计算上的错误和疏漏;计算机技术的全面普及,打破了财务管理的传统管理方法,提高了管理效率的同时,克服了传统管理方法中易产生的问题,使管理员能够有序的、全面的对每一位职工进行管理,严格按照工资条款及发放制度计算并发展员工工资。企业工资管理系统可以完成日常工资的管理,如查询、修改、增加、删除以及存储等操作,迅速准确地完成各种工资数据的的统计和汇总

4、工作,快速打印出工资报表等,大大提高了企业的管理效率。1 系统需求分析根据市场的需求,要求系统具有以下功能: 对单位人员的变动进行处理。 对职工的工资进行计算、修改。 查询统计功能。 报表打印功能。2 总体设计2.1 项目规划工资管理系统是由基本信息管理、工资查询、工资管理、系统管理和帮助等几个功能模块组成,规划系统功能模块如下: 基本信息管理模块基本信息管理模块主要包括员工录入、员工删除2部分。 工资查询模块工资查询模块主要包括基本工资查询、浮动工资查询、加班/休假查询、总体查询4个部分。 工资管理模块工资管理模块主要包括工资发放管理、基本工资管理、浮动工资管理3个部分。 系统管理模块系统管

5、理模块主要包括用户管理、修改密码、退出系统3个部分。 帮助模块帮助模块主要包括关于1个部分。2.2 系统功能结构工资系统的功能结构如图1所示。图1 系统功能图2.3 设计目标本系统是根据中小企业的实际需求而开发的,完全能够实现企业对客户的自动化管理,通过本系统可以达到以下目标: 系统运行稳定,安全可靠。 界面设计美观,人机交互界面友好。 信息查询灵活、方便、快捷、准确,数据存储安全可靠。 满足键盘和鼠标的双重操作,完全支持回车键。 采用多种方式查询数据。 操作员可以随时修改自己的口令。 对用户输入的数据,系统进行严格的数据检验,尽可能排除人为的错误。 数据保密性强,为每个用户设置相应的权限级别

6、。3 系统设计3.1 开发及运行环境1硬件要求CPU:300MHz以上的处理器。内存:128MB,推荐256MB。硬盘:150MB以上剩余空间。显示像素:最低800*600,最佳效果1024*768。2软件要求操作系统:Windows2000/NT/XP/CE。数据库:SQL Server2000。3.2 数据库设计1数据库概要说明数据库GZFFXT中包括员工基础信息表、员工基本工资表、员工浮动工资表、员工加班/休假表、工资发放明细表、用户表6个数据表。图2所示的即为本系统中数据库中的数据表结构图,该数据表结构图包含系统所有数据表。可以清晰地反应数据库信息。图2 数据库概要说明2主要数据表的结

7、构数据库中的数据表请参见附录B。4 主要功能模块设计4.1 建立工程框架在Visual C+中建立文档管理系统的基本框架,步骤如下:(1)单击菜单“File-New”命令,打开“New”对话框,单击“Projects”选项卡,选择“MFC AppWizard(exe)”,输入工程名,并设置路径,如图3所示。图3 “New”对话框(2)单击“OK”按钮,“MFC AppWizard-Step1”对话框已经打开,如图4所示,选项“Dialog base”,接着单击“Next”按钮。图4 “MFC AppWizard-Step 1”对话框(3)在弹出的“MFC AppWizard-Step 2 of

8、 4”对话框中,输入对话框标题,如图5所示。图5 “MFC AppWizard-Step 2 of 4”对话框(4)在接下来的对话框中保持默认的选项。设置好的属性如图6所示,单击“OK”按钮后,就完成了新建工程。图6 设计好的工程属性44.2 主窗口设计1菜单资源设计主窗口菜单设置的主要步骤如下:(1)单击“ResourceView”选项卡,右键单击“GZGLXT Resources”选项,选择“Insert”菜单项,打开“Insert Resource”窗口,如图7所示。图7 “Insert Resource”窗口(2)选择“Menu”文件夹,单击“New”按钮,在GZGLXT Resour

9、ces目录下新增一个Menu目录项,菜单ID为IDR_MENU1。双击此菜单,对此菜单项的属性进行设计。如图8所示。图8 设计菜单属性图2客户区设计(1)打开对话框IDD_GZGLXT_DIALOG属性窗口,在对话框中添加1个Picture控件,用来存放图片。在Menu组合框中选择IDR_MENU1。如图9所示。图9 系统主界面(2)预先在下边留出状态栏,声明CTime、CstatusBarCtrl类对象实体代码如下。 CTime t; CStatusBarCtrl m_StatusBar;引用的外部变量extern CCzyxxb ffxxb;(3)在OnInitDialog成员函数中添加状

10、态栏。 / TODO: Add extra initialization here t=CTime:GetCurrentTime(); m_StatusBar.EnableAutomation(); m_StatusBar.Create(WS_CHILD|WS_VISIBLE,CRect(0,0,0,0),this,0);/ID_STATUSBAR); int width=200,370,500; m_StatusBar.SetParts(4, &width0); m_StatusBar.SetText(吉林省明日科技有限公司,0,0); CString StatusText; StatusT

11、ext.Format(当前用户:%s,ffxxb.GetCzyName(); m_StatusBar.SetText(StatusText,0,1); CString strdate; strdate.Format(当前时间:%s,t.Format(%y-%m-%d); m_StatusBar.SetText(strdate,0,2); return TRUE; / return TRUE unless you set the focus to a control(4)打开ClassWizard窗口,为菜单项ID_EXIT添加代码。程序调用OnOK()函数关闭对话框,退出系统。void CGZ

12、GLXTDlg:OnExit() / TODO: Add your command handler code here OnOK();4.3 登录模块设计1实现目标登录模块功能是完成用户登录本系统的操作,用户登录对话框的设计如图10所示图10 登录对话框2设计步骤(1)向项目中添加一个新Dialog资源,资源ID为IDD_LOGIN。在IDD_LOGIN对话框资源中单击鼠标右键,执行弹出快捷菜单的“Properties”菜单命令,打开“Dialog Properties”对话框。在“Dialog Properties”对话框中选择General选项卡,更改其“Caption”文本框内容为“用户

13、登录”。(2)从Controls面板上向Dialog资源中添加2个Static、1个Picture、2个Edit,更改资源的属性,并为资源设置相对应的变量,如表1所示。表1 资源设置IDPropertiesMember VariablesTypeMemberIDC_EDIT1默认CStringm_nameIDC_ EDIT2PassWord TRUECStringm_pwdIDOKCaption 登录IDCANCELCaption 退出IDC_STATICType Bitmap3代码分析(1)引用的外部变量。extern CCzyxxb ffxxb; (2)响应“登录”按钮的代码。void C

14、Login:OnOK() / TODO: Add extra validation here /将对话框中编辑框的数据读取到成员变量中 UpdateData(true); if(m_name=) MessageBox(请输入用户名); return; /如果读取数据和用户输入不同,则返回 if(ffxxb.HaveCzy(m_name,m_pwd)!=1) MessageBox(用户名或密码错误!); return; ffxxb.SetCzyName(m_name); jb=1; /判断当前用户级别 if(ffxxb.HaveCzyjb(m_name,m_pwd,jb)=1) ffxxb.Se

15、tCzyjb(jb); CDialog:OnOK();下面在主对话框中添加代码,使对话框在启动时首先打开登录对话框。在主窗口选择OnInitDialog函数,该函数将打开登录对话框,如果用户不是通过单击“登录”按钮关闭对话框,则调用OnOK函数关闭主对话框,具体代码如下:BOOL CWordGLXTDlg:OnInitDialog() CDialog:OnInitDialog();./ TODO: Add extra initialization hereCLogin gin; if(gin.DoModal()!=IDOK) OnOK();.return TRUE; / return TRUE

16、 unless you set the focus to a control4.4 员工录入模块设计1实现目标添加员工信息,员工录入对话框的设计如图11所示图11 员工录入对话框2设计步骤(1)向项目中添加一个新Dialog资源,资源ID为IDD_YGTJK。在IDD_YGTJK对话框资源中单击鼠标右键,执行弹出快捷菜单的“Properties”菜单命令,打开“Dialog Properties”对话框。在“Dialog Properties”对话框中选择General选项卡,更改其“Caption”文本框内容为“员工录入”。(2)从Controls面板上向Dialog资源中添加4个Stati

17、c、2个Combo、2个Edit,更改资源的属性,并为资源设置相对应的变量,如表2所示。表2 资源设置IDPropertiesMember VariablesTypeMemberIDC_EDIT1默认CStringm_idIDC_ EDIT2默认CStringm_name IDC_COMBO1Type BitmapCComboBoxm_sexIDC_COMBO2Caption 退出CComboBoxM_whcdIDOKCaption 添加IDCANCELCaption 退出3代码分析(1)打开ClassWizard窗口,添加在OnInitDialog成员函数,向OnInitDialog添加代码

18、如下。BOOL CYgjctjdlg:OnInitDialog() CDialog:OnInitDialog(); / TODO: Add extra initialization here SetIcon(m_hIcon, TRUE); m_sex.AddString(男); m_sex.AddString(女); m_whcd.InsertString(0,专科); m_whcd.InsertString(1,本科); m_whcd.InsertString(2,研究生); return TRUE; / return TRUE unless you set the focus to a c

19、ontrol / EXCEPTION: OCX Property Pages should return FALSE(2)当用户单击“添加“按钮时,实现添加员工功能,其响应代码如下void CYgjctjdlg:OnOK() / TODO: Add extra validation here CYgjcxxb xxb; UpdateData(true); if(m_id=) MessageBox(编号不能为空); return; if(m_name=) MessageBox(姓名不能为空); return; if(xxb.HaveId(m_id)=1) MessageBox(员工编号已存在);

20、 return; xxb.SetYGid(m_id); xxb.SetYGxm(m_name); CString sex,whcd; m_sex.GetWindowText(sex); if(sex=) MessageBox(性别不能为空); return; /从组合框中读取文本 m_sex.GetLBText(m_sex.GetCurSel(),strsex); xxb.SetSex(strsex); m_whcd.GetWindowText(whcd); if(whcd=) MessageBox(文化程度不能为空); return; m_whcd.GetLBText(m_whcd.GetC

21、urSel(),strwhcd); xxb.SetWHcd(strwhcd); xxb.sql_insert(); /向浮动工资表添加编号、姓名 CYgfdgzxmb xmb; xmb.SetYGid(m_id); xmb.SetYGxm(m_name); xmb.sql_insert(); /向基本工资表添加编号、姓名 CYgjbgzb gzb; gzb.SetYGid(m_id); gzb.SetYGxm(m_name); gzb.sql_insert(); /向加班休假表添加编号、姓名 CYgjbsjb sjb; sjb.SetYGid(m_id); sjb.SetYGxm(m_name

22、); sjb.sql_insert(); CDialog:OnOK();4.5 员工工资添加模块设计1实现目标添加员工实际发放的工资情况,员工工资添加对话框设计如图12所示。图12 员工工资添加对话框2设计步骤(1)向项目中添加一个新Dialog资源,资源ID为IDD_YGGONGZITJ。在IDD_YGGONGZITJ对话框资源中单击鼠标右键,执行弹出快捷菜单的 “Properties”菜单命令,打开“Dialog Properties”对话框。在“Dialog Properties”对话框中选择General选项卡,更改其“Caption”文本框内容为“员工工资添加”。(2)从Contro

23、ls面板上向Dialog资源中添加19个Static、17个Edit、2个Button控件,更改资源的属性,并为资源设置相对应的变量,如表3所示。表3 资源设置IDPropertiesMember VariablesTypeMemberIDC_EDIT1默认CStringm_idIDC_EDIT2默认CStringm_nameIDC_EDIT3默认intm_jbgzIDC_EDIT4默认intm_zwgzIDC_EDIT5默认intm_glgzIDC_EDIT6默认intm_zfbzIDC_EDIT7默认intm_shbzIDC_EDIT8默认intm_bxfIDC_EDIT9默认intm_j

24、iabtsIDC_EDIT10Read-only TRUECEditm_jiabgzIDC_EDIT11默认intm_sjtsIDC_EDIT12Read-only TRUECEditm_sjgzIDC_EDIT13默认intm_ylbxjIDC_EDIT14默认intm_grsdsIDC_EDIT15默认intm_sfgzIDC_EDIT16Read-only TRUECEditm_yfgzIDC_EDIT17Read-only TRUECEditm_syyeIDOKCaption 添加IDCANCELCaption 退出IDC_BUTTONsyyeCaption 上月余额IDC_BUTTO

25、NyfgzCaption 应发工资3代码分析(1)双击“IDC_EDIT9”控件,自动生成OnChangeEdit9函数,实现用户添加加班天数时,加班工资自动计算并显示,具体代码如下:void CYggztjdlg:OnChangeEdit9() / TODO: If this is a RICHEDIT control, the control will not / send this notification unless you override the CDialog:OnInitDialog() / function and call CRichEditCtrl().SetEvent

26、Mask() / with the ENM_CHANGE flag ORed into the mask. UpdateData(true); CString str; str.Format(%d,m_jiabts*40); m_jiabgz.SetWindowText(str); UpdateData(false); / TODO: Add your control notification handler code here (2)双击“上月余额”按钮,系统自动添加消息响应函数OnBUTTONsyye,具体代码如下。void CYggztjdlg:OnBUTTONsyye() / TODO

27、: Add your control notification handler code here UpdateData(true); if(m_id=) MessageBox(请先填写员工编号); return; ADOConn m_AdoConn; m_AdoConn.OnInitADOConn(); t = CTime:GetCurrentTime(); int m,y; CString str; m=t.GetMonth()-1; y=t.GetYear(); if(m=0) m=12; y=y-1; CGzffmxb mxb; if(mxb.Havesyye(m_id,y,m)=1)

28、 CString sql; sql.Format(select * from gzffmxb where ygid=%s and year(sjian)=%i and month(sjian)=%i,m_id,y,m); m_AdoConn.GetRecordSet(_bstr_t)sql); str=(char*)(_bstr_t)m_AdoConn.m_pRecordset-GetCollect(Yu_E); m_syye.SetWindowText(str); else m_syye.SetWindowText(0); UpdateData(false); m_AdoConn.ExitC

29、onnect();在头文件中添加下列代码。CTime t;(3)双击“应发工资”按钮,系统自动添加消息响应函数OnBUTTONyfgz,具体代码如下:void CYggztjdlg:OnBUTTONyfgz() / TODO: Add your control notification handler code here UpdateData(true); CString syye; m_syye.GetWindowText(syye); if(syye=) MessageBox(请先添加上月余额); return; int yfgz; yfgz=atoi(syye)+m_jbgz+m_glgz+m_zwgz

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1