11前言课程设计是对学生的一种全面综合训练,是与课堂听讲、自学和练习相辅相成的、必不可少的一个教学环节。通常,课程设计中的问题比平时的习题复杂得多,也更接近实际。课程设计着眼于原理与应用的结合点,使学生学会如何把书上学到的知识用于解决实际问题,培养软件工作所需要的动手能力。另一方面,使书上的知识变活,起到深化理解和灵活应用教学内容的目的。平时的习题局限于一个和二个知识点,而课程设计题是软件设计的综合训练,包括问题分析,总体结构设计,用户界面设计、程序设计、基本技能和技巧,以及一整套软件工作规范的训练和科学作风的培养。我们这组选的课题是工资管理系统的设计与开发。从接到任务书开始,我们首先完成了系统的需求分析与概要设计,在完成这些任务时,我们深感理论与实践的结合的是需要一个过程。从个人分工到整个系统分析,从设计到测试之所以能顺利完成是和大家的努力分不开的。虽然还有一些不足之处,但是我们还是从中获益不少。下面简要介绍一下我们课题组的分工,我们这组的分工其实借鉴了ShariLawrencePfleeger和JoanneM.Atlee合著的SOFTWAREENGINEERINGTheoryandPractice(高等教育出版社第三版影印版)中的一些理论,这些知识可以参考此书的第25页中关于“开发团队的角色分工”一节。根据分工的细化和部分重叠原则,我们组的具体分如下:(1)项目管理:王培(2)需求分析:钟耀明、贺纯(3)概要设计:贺纯、赵亦娴(4)详细设计:赵亦娴、王培、钟耀明、杨安、陈华、贺纯(5)程序编码:王培、陈华(6)系统测试:陈华、杨安我的主要任务是概要设计和详细设计22需求分析2.1任务概述现代企业基本上都引进了计算机软件对公司业务进行管理,这样做有很多优点,一是提高了工作的效率,同时也减少了手工操作的错误以及人员的开支。本课题开发的工资管理系统正是基于这样的目的实现的,系统完成的主要功能是对员工工资的管理,同时还包括对员工信息、部门信息以及附属于员工、部门的职称和职务信息的管理。系统主要采用事务型数据库设计,但对于员工工资的信息,系统能够保留其相应的历史记录,包括员工的请假信息,出差信息以及工资结算信息等。本系统面向员工和管理人员同时开放,普通用户可以进行查询以及对个人相关信息的修改等操作,管理账户则拥有系统的全部功能。系统不允许非经认证通过的用户使用系统。系统采用JAVA语言开发,系统的数据使用ORACLE数据库进行管理。2.2功能需求分析(1)系统能够维护员工的基本信息,部门、职务、职称以及工资记录等信息。(2)系统应该能记录员工的每一个职称信息,并授予相应的职称,系统在计算员工工资的时候选取职称对应的最高职称津贴。(3)工资表应当由系统自动生成。系统负责员工的工资表以及员工工资的历史记录及记录员工的请假信息和出差信息等意外情况。(4)系统可以给管理员提供权限增加删除修改系统用户以及其它实体信息,系统的部分权限不能下放给普通用户以保证系统的安全性以及数据的正确性。2.3外部接口需求分析系统人机交互界面为半屏幕大小,采用上下左右居中方式显示,系统分辩率默认设置为1280*800,实际的界面大小由具体的屏幕决定。主界面包括标题栏,菜单栏,快捷工作区,帮助信息区(默认是隐藏的)。每一个菜单对应一个键盘快捷键区。2.4性能需求分析3系统在主频1.5GHZ,内存512MB,总线频率667MHZ的硬件平台上运行时,系统的响应时间、更新处理时间、数据转换与传输时间、运行时间均能达到毫秒级。系统支持用户并发操作,事务采用可串行化隔离级别,防止在读写过程中产生的丢失修改、读脏数据、不可重复读等一系列由并发操作带来的不一致问题。系统的运行主存控制在1024KB以内,响应时间控制在1000ms以内,系统对数据的存储空间取决于数据库系统表空间的约束限制。2.5软件属性需求分析系统必须保证所有操作结果以及存储数据的正确性,对于用户的非法操作,系统必须能够提出告警信息,对于用户的错误操作,系统能够提供错误信息以及错误源。在数据库操作上的异常,系统也应捕捉到并提供界面化的提示信息,对于可能会产生错误的操作,应当能够防范。另外系统必须提供一定的安全保密性,一些保密信息只针对特定的用户提供。它人员无法访问。软件必须为中文操作界面,并且所有的中文功能菜单项描述须与其实际对应的功能相一致,不能存在功能不足或者功能不对的情况,软件采用面向对象技术架构,遵循代码编写规范,提供适当的代码注释,尽可能地采用可复用技术,提高软件的可维护性。3概要设计3.1系统设计总体思想当工资管理系统处理的事务主要有工资管理,员工信息管理,部门信息管理,职务信息管理,职称信息管理。职务和职称以及部门信息管理主要服务于工资管理和员工信息管理,系统接收的输入项目有员工信息,部门信息,职务信息,职称信息,请假信息,出差信息等。系统能够接受用户的请求,显示相应的查询信息,增加、删除、修改相应的合法的信息。4图3.1.1工资管理系统HIPO图图3.1.1是工资管理系统的HIPO图,上图主要说明了系统的各个主要功能以及各功能模块之间的层次关系。上图的基本框架也是整个系统界面的基要框架。系统的人机交互采用图形化用户界面,考虑到系统的平台无关性,系统由JAVA语言实现,系统的界面元素也是采用了JAVA的JFC图形类库。系统可以在安装了JAVA运行环境的平台上运行。系统从登录界面开始,要求验证用户信息,用户通过验证后,进入系统主界面。主界面提供了一个菜单框架,可以通过各个菜单类的一个实例来加载菜单,这一步不是由主界面完成的,而是由所需要被加载的类完成的,但需要主界面类去生成这些菜单英的实例。系统加载的功能主要包括系统管理,用户管理,工资管理,部门管理,职务管理,职称管理以及适当的帮助信息。系统管理主要向用户提供用户更改密码的操作以及退出程序的功能。用户管理允许管理员新建一个员工信息,比如当公司新增加了一个员工时,系统为该员工生成相应的工资关系,但新建这个员工的信息则是第一环节,当然如果公司离任了一名员工时,此员工与公司的工资关系已解除,则没有必要保留该员工的信息,系统应向管理员提供删除该员工的功能,同时删除与该员工相关的所有其它信息。公司所在的员工可能有部分具有相应的职称,考虑到职称的种类繁多,系统只添加本公司员工所拥有的职称的一个集合,而不考虑外界的因素,因5此系统提供了增加、删除、修改、查询等对职称的相关操作。例如,当公司一员工拿到高级职称后,管理员首选应该查看系统是否记录了相应职称的信息,如果有,则直接将该职称信息添加到员工信息中去,如果没有,则应当先增加这一职称信息,再执行上述操作。另外在删除一个职称的时候,系统要求必须没有员工拥有此职称,否则系统不能删除,如果确实要删除,则只能先删除拥有此职称的所有员工或者撤销拥有此职称的所有员工的此职称。3.2系统功能模块设计图3.2.1系统功能模块设计3.3系统数据库设计通过对工资管理系统的数据分析并根据业务之间的联系,我们可以得出与系统相关的实体有:员工、部门、职务、职称、请假信息、出差信息、工资。工资管理系统的数据据库管理模式用语义描述如下:(1)每一个员工只能属于一个部门,担任一个职务,但是可以拥有多个职称.(2)每个部门可以有多名员工,有不同的职务.(3)每个职务可以由多名员工担任,可以在相同的部门,也可以在不同的部门.6(4)每个职称可以授予不同的员工.(5)每个员工每个月都会有一份工资记录,并且会有一份历史工资记录.(6)员工每个月可以请假多次或者出差多次.但是要扣除相应的工资或者获得相应的补助.每个员工都有一分历史请假记录和历史出差记录。综合上述语义,可以得出系统的ER图如图3.3.1所示:3.3.1工资管理系统ER图根据实体之间的联系,以及分析实体的属性,得出了工资管理系统中各个实体的属性,相关属性列表见表3.3.1。表3.3.1工资管理模型的相关属性列表实体或联系属性员工员工编号、姓名、性别、部门号、职务部门部门编号、名称、人数、电话职务职务编号、名称、基本工资职称职称编号、名称、职称津贴出差信息出差编号、员工编号、天数、出差年份、出差月份、出差补助7员工职称信息员工编号、职称编号请假信息请假编号、员工编号、天数、年、月、扣除工资、请假原由工资工资编号、员工编号、工资所属年月、基本工资、扣除工资、出差补助、岗位工资、职称津贴、工资总额说明:加粗部分为主键,加底线部分为外键图3.3.2实体及其相关属性图4详细设计4.1数据结构设计4.1.1数据库表结构设计Employee——员工信息表字段名数据类型约束名称说明empnonumber(6)主键员工编号8enamevarchar2(20)notnull员工姓名sexvarchar2(4)notnull性别deptnonumber(6)外键department(deptno)部门编号dutynonumber(6)外键duty(dutyno)职务编号Department--部门信息表字段名数据类型约束名称说明deptnonumber(6)主键部门编号deptnamevarchar2(20)notnull部门名empnumnumber部门人数telnumber电话Duty--职务信息表字段名数据类型约束名称说明dutynonumber(6)主键职务编号dutynamevarchar(20)notnull职务名dutypaynumberdefault(0),check(dutypay=0)职务基本工资Title--职称信息表字段名数据类型约束名称说明titlenonumber(6)主键职称编号titlenamevarchar2(20)notnull职称名titlepaynumberdefault(0),check(titlepay=0)职称津贴TitledEmployee--员工职称联系表字段名数据类型约束名称说明empnonumber(6)组合主键,外键employee(empno)员工编号titlenonumber(6)职称编号yearnumber(4)年记录职称授予时间monthnumberbetween1and12月Leave--员工请假信息表字段名数据类型约束名称说明leavenonumber(6)主键请假编号9empnonumber(6)外键employee(empno)请假员工leavedaysnumbernotnull请假天数leaveyearnumber(4)notnull请假年份leavemonthnumbernotnull请假月份deductionnumbernotnull扣除工资reasonvarchar(60)请假原因BusinessTravel--出差信息表字段名数据类型约束名称说明travelnonumber(6)primarykey出差编号empnonumber(6)外键employee(empno)员工编号traveldaysnumbernotnull出差天数travelyearnumber(4)notnull出差年份travelmonthnumbernotnull出差月份travelpaynumbernotnull出差补助Reward--奖励信息表字段名数据类型约束名称说明rewardnonumber(6)primarykey奖励编号empnonumber(6)外键employee(empno)员工编号rewardyearnumber(4)notnull奖励年份rewardmonthnumbernotnull奖励月份rewardpaynumber奖励金额reasonvarchar(60)奖励原由Penalty--罚金信息表字段名数据类型约束名称说明penaltynonumber(6)primarykey罚金编号empnonumber(6)外键employee(empno)员工编号penaltyyearnumber(4)notnull罚金年份penaltmonthnumbernotnull罚金月份penaltynumnumber罚金额度reas