职工工资管理系统设计与实现.doc
《职工工资管理系统设计与实现.doc》由会员分享,可在线阅读,更多相关《职工工资管理系统设计与实现.doc(36页珍藏版)》请在三一办公上搜索。
1、JAVA程序设计课程设计报告 设计题目: 职工工资管理系统设计与实现 学院名称: 专业班级: 姓 名: 学 号: 目录一 需求分析。3二 概要设计。3三 详细设计。5 3.1 数据库设计。3 3.2 模块及窗体设计。3 3.2.1 数据库模块设计。53.2.2 用户登录识别模块。63.2.3管理员模块。 8 职工基本信息管理。 9 职工工资管理。203.2.4 普通用户模块。 28 职工信息。283.2.5 系统管理模块。153.2.5 主窗体菜单设计。15四 软件测试。36五 总结。36参考资料:。17一 需求分析 本系统的主要目的就是实现职工工资管理系统设计与实现,使职工工资管理工作更加容
2、易, 高效地管理企业职工工资,从而提高工作效率,降低管理成本. 二 概要设计/*概要设计阶段主要是粗略描述整个软件的框架,并从业务的角度描述软件的模块、工作流程等。项目的成功取决于设计的好坏,而概要设计则是整个设计的关键部分。概要设计的主要任务是将用户的需求划分为不同的功能,然后将这些功能细分成模块,并给模块一些规则约束,以达到各个模块之间可以相互交流的目的。概要设计关乎到系统的整体架构,因此想做好一个概要设计,不仅仅要熟悉用户的业务流程,还要具备相当丰富的设计经验。2.1 概要设计的原则概要设计是根据系统分析的需求和工作环境的情况对整个软件的总体结构进行大致的设计。概要设计要坚持以下几个原则
3、。(1)细分原则:软件系统都是由很多不同的模块组成,当设计一套软件时,要先将所有的功能分解。解决复杂问题的方法是将其分解成几个小问题,一个个来解决。(2)提高代码重用性:在面向对象设计中,首先考虑的就是代码的重用,一个好的设计,将来在升级换代时不需要太大的改动,节省了人力物力。(3)从上而下层层分析:概要设计要从整体出发,逐个剖析软件的功能,从上而下,先分析系统总的功能,然后一步步细分,直到最小的功能模块。(4)一致性原则:概要设计要求所有功能模块在定义时使用统一的规范。(5)提高独立性,减少耦合:各个模块与模块之间尽量减少关联,否则修改一个地方就会引起其他多处的变动,不符合面向对象的原则。一
4、般情况下,对类封装后,只允许对类进行扩展,而不能修改,而封装的类必须具有单一职责,既理论情况下不允许两个类共同完成一个功能。(6)模块的大小要尽量适中:不是结构算法越复杂的模块越好,模块的大小要根据实际工作目标和其他类的耦合紧密程度来决定。经验表明,一个模块的规模不应过大,模块的总行数应控制在10100行的范围内,最好为3060行,这样理解和阅读都较方便。过长的模块往往是分解不充分的表现,会增加阅读理解的难度;但小规模太多也会使模块之间联系变得复杂,增大系统在模块调用时传递信息所花费的开销。由于概要设计是整个设计的重中之重,牵一发而动全身,所以要努力做一个好的概要设计,才能在今后软件开发过程中
5、不再反复。现在软件行业流行模式化驱动设计,将一些市场上比较成功的模式拿来用在自己的设计中。2.2 将用户需求模块化根据概要设计的原则来分析一下本项目的用户需求,并最终转化成用程序语言描述的模块。什么样的需求才是一个模块?模块应该具备如下3个特征。(1)输入和输出:模块必须能被调用并且正确的返回调用,而且调用都是相对一个对象而言,这是模块独立性的一个体现。(2)处理功能:模块必须可以对调用的输入数据进行灵活的处理,并为输出准备好处理结果。(3)程序代码:用来实现模块功能的源代码。2.3 确定系统最终模块概要设计中最重要的就是确定此项目包括哪些模块。根据上两节讲述的设计原则和模块特征,将用户需求转
6、化为下面的模块。*/(1)流程图设计2.2 模块设计1 数据库设计模块2 用户登录识别模块3 用户信息管理模块4 职工信息管理模块2.2.1 程序功能描述1. 程序运行之后首先弹出欢迎窗口,继而进入登陆界面2. 登陆界面的通过用户密码验证进入操作3. 密码输入正确后转入管理员主菜单,就可以选择对职工基本信息和工资进行计算、修改、添加或者查询或退出后回到主菜单。4. 密码输入正确后转入普通用户主菜单,就可以选择对自身基本信息和工资进行计算或者查询或退出后回到主菜单。5. 每个功能模块都有退出的功能,回到主菜单。6. 点击主菜单的退出按钮,退出系统。三 详细设计3.1 数据库设计数据库名称:emp
7、loyee 表名:user, employ,salary表user:存放登陆用户的用户名和密码表employ:存放职工基本信息职工表(employee)字段名类型备注EmployIDchar(20)职工号EmployNamechar(30)Not nullEmploySexchar(2)性别男 或者女EmployAgeint年龄0EmployDeptchar(30)部门EmployAdchar(50)住址EmpoyJobChar(20)职务Not nullEmployPhInt电话号工资表(salary)字段名类型备注EmployIDchar(20)职工号Not nullEmbaseSalar
8、yInt基本工资=0EmAddSalaryint奖金EmSubSalaryint罚金SalaryCardint工资卡Not nullRealSalaryint实发工资Not null3.2 模块及窗体设计3.2.1 数据库模块设计将数据库的连接包装在一个DBConnect类中,以便其他模块能够轻松调用,避免每次重写数据库连接代码。下表是他的基本属性文件名成员变量成员方法database.javapublic static Connection cn;public static Statement st; public static ResultSet rs;public static void
9、 closeConn(Connection conn);public static Connection getConn() throws Exception代码如下:/创建数据库连接类DBConnectpackage Java_Design;import java.sql.*;public class JDBConnect/静态方法提高数据库的连接效率public static Connection getConn() throws Exception/加载JDBC驱动Class.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver);re
10、turn DriverManager.getConnection(jdbc:sqlserver:/localhost:1433; +databasename=SalaryManagement,sa,1sjk);/关闭连接 public static void closeConn(Connection conn) if(conn != null) try conn.close(); catch (Exception e) e.printStackTrace(); /关闭执行对象public static void closeStatement(Statement stmt) if(stmt !=
11、 null) try stmt.close(); catch (Exception e) e.printStackTrace(); /关闭结果集public static void closeResultSet(ResultSet rs) if(rs != null) try rs.close(); catch (Exception e) e.printStackTrace(); 3.2.2 用户登录识别模块下表其他的基本属性文件名成员变量成员方法landing1.javaJLabel jlabel2=new JLabel(用户ID:);JLabel jlabel3=new JLabel(密
12、码:);JTextField text1 = new JTextField(); public landing1() 判断用户名和密码是否正确的成员方法代码: private class BHandler implements ActionListener public void actionPerformed(ActionEvent e) name=text1.getText(); if (e.getSource()=button1) if(text1.getText().trim().equals()| text2.getText().trim().equals() JOptionPane
13、.showMessageDialog(null,信息不能为空!); try ResultSet rs1=st.executeQuery(select * from Employee where EmployID=+text1.getText()+); if(rs1.next() ) Name=rs1.getString(EmployName).trim(); if(text2.getText().equals(rs1.getString(EmployPassword).trim() if(mana.isSelected() if(rs1.getString(EmployJob).trim().
14、equals(管理员) dispose(); Management Management1 = new Management(rs1.getString(EmployName).trim(); Management1.setVisible(true); else JOptionPane.showMessageDialog(null,非管理员!); else if(pers.isSelected()/j普通用户 dispose(); Person Person1 = new Person(rs1.getString(EmployName).trim(),rs1.getString(EmployI
15、D).trim(); Person1.setVisible(true); else JOptionPane.showMessageDialog(landing1.this,password error!); else JOptionPane.showMessageDialog(landing1.this,登录超时!没有这个用户!); catch(Exception ex) /利用消息对话框提示失败 JOptionPane.showMessageDialog(landing1.this,登录超时!没有这个用户!); text1.setText(); text2.setText(); else i
16、f (e.getSource()=button2) text1.setText( ); text2.setText( ); else if(e.getSource()=jMenuItem1)/上页dispose(); index m= new index(); m.setVisible(true); else if(e.getSource()=jMenuItem4)/退出 System.exit(0); 3.2.3 管理员模块下表其他的基本属性文件名成员变量成员方法Management.javaJMenu jMenu0=new JMenu(系统_管理员界面);/菜单JMenuItem jMen
17、uItem1=new JMenuItem(主页);/子菜单JButton addButton = new JButton(); private class BHandler implements ActionListener public void actionPerformed(ActionEvent e) if(e.getSource()=jMenuItem1)/主页public Management(String name)代码:public Management(String name)/传过来管理员的nameName=name;setTitle(Welcome Management_
18、+Name);/ 设置窗体标题 setSize(800, 600); setBounds(100, 100, 550, 340);/ 设置窗体位置 setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setResizable(false); setContentPane(contentPane);/ 设置窗体内容面板 BHandler h=new BHandler();/为组件注册监听器 indexBackgroundP backgroundPanel = new indexBackgroundP();/ 创建背景面板 backgroundPanel
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 职工工资 管理 系统 设计 实现
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-4296458.html