面向对象技术课程设计a人事工资管理系统课程设计大学论文.docx
《面向对象技术课程设计a人事工资管理系统课程设计大学论文.docx》由会员分享,可在线阅读,更多相关《面向对象技术课程设计a人事工资管理系统课程设计大学论文.docx(25页珍藏版)》请在冰豆网上搜索。
面向对象技术课程设计a人事工资管理系统课程设计大学论文
面向对象技术课程设计A任务书
一、课程设计目的
“面向对象技术”是计算机科学与技术专业的核心专业课,面向对象程序设计技术也是软件工程师的基本技能,“面向对象课程设计”的目的是理解和巩固面向对象程序设计的基本理论、原理和方法的重要的实践环节。
本课程设计综合应用学生所学知识,结合小型应用系统的设计,建立面向对象程序设计的概念,理解和巩固封装、类与对象、继承与多态、JAVA数据结构、多线程、IO、UI设计及UML等知识,掌握常用设计模式知识以及分层设计思想,为后续课程的学习打下良好的基础。
二、课程设计阶段教学内容与任务
本课程设计分二个阶段,第一阶段为课程知识的复习与巩固,教学形式为讲授与训练相结合(算法与程序设计基础课程设计实施计划);第二阶段为项目实战案例与职业素养教育,以学生编程训练为主,在这一阶段,学生需要以分组为单位,完成以下实训项目:
人事管理系统。
三、选题要求、学时分配和辅导
选题要求
(1)以学号的最低位为选题依据,每人1题,独立完成各自的任务。
(2)任务完成后,以小组为单位,独立撰写课程设计报告并打印。
四、评分和验收标准
1评分标准
课程成绩组成:
平时+任务合作与设计质量+课程设计报告质量
2验收标准
教师根据设计报告、软件的运行演示和学生回答问题的情况评定成绩。
(1)设计报告规范、完整,概念原理论述清楚、软件设计结构合理,独立完成设计,软件运行正常,能够突出表现多道程序运行的特点,回答问题准确明了,可以评为优秀(A)。
(2)设计报告规范、完整,概念原理论述清楚、软件设计结构合理,独立完成、软件基本运行正常,能够表现多道程序运行的特点,回答问题正确,可以评为良(B)。
(3)设计报告规范、概念原理论述基本清楚、软件设计结构合理,基本独立完成,软件基本运行正常,基本能够表现多道程序运行的特点,回答问题部分正确,可以评为中良(C)。
(4)设计报告基本规范、概念原理论述基本清楚、软件设计结构基本合理,部分独立完成,软件基本可以运行,基本能够表现多道程序运行的特点,回答问题部分正确,可以评为及格(D)。
(5)设计报告不规范、概念原理论述不清楚、软件设计结构不合理,大部分不能独立完成,软件基本不能运行,回答问题大部分不正确,可以评为不及格(E)。
五、设计的基本步骤
(1)需求分析
查找相关技术资料,了解基本原理,根据题目要求的功能,确定运行流程。
.
(2)设计软件的界面
程序运行界面要求使用中文或中英文对照.。
(3)总体设计、
用UM图实现:
用例图、类图、状态图、时序图
确定软件的总体结构、模块关系、总体流程;
确定开发要使用的语言环境;
要解决的关键技术问题。
(4)详细设计
确定要使用的函数、API,掌握它们的使用的参数和返回值。
确定模块内部的流程和实现算法;
确定要设计的过程、构件、类、对象、函数和它们的参数。
(5)编码设计
建立设计编程的环境;
注意编程的风格的规范。
(6)实际数据运行测试
检查程序是否有错误;
检查界面是否美观;
检查操作是否方便;
检查提供的信息是否清晰;
检查性能是否稳定。
六、设计说明书内容要求
6.1概述
目的:
实现人事管理。
主要完成的任务:
实现了员工信息的查询,对员工信息的增、删、改,对员工工资的查询,和对员工信息的统计,数据的备份和恢复。
使用的开发工具:
Myeclipse8.5,MySQL。
解决的主要问题:
解决了对员工信息的管理,对工资的统计。
6.2总体设计
确定基本的技术路线:
面向对象。
确定软件的总体结构、模块关系、总体流程:
6.3详细设计
1.ResultSetexecuteQuery(String sql)throwsSQLException//执行给定的SQL语句,该语句返回单个ResultSet对象。
参数:
sql-要发送给数据库的SQL语句,通常为静态SQLSELECT语句;返回:
包含给定查询所生成数据的ResultSet对象;永远不能为null;抛出:
SQLException-如果发生数据库访问错误,在已关闭的Statement上调用此方法,或者给定SQL语句生成单个ResultSet对象之外的任何其他内容。
2.
3.主要的方法体:
public User login(User user);//登录方法
public Vector findUserAll();//查找所有员工信息
public void backUp(User user);//数据备份
public User recOver();//数据恢复
public Vector showUserType();//显示用户种类
public Vector showUserTypeMain();//显示用户种类
public int updateUserType(UserType userType);//更新用户种类
public int saveUserType(UserType userType);//保存用户种类
public int removeUserType(int tid);//删除用户种类
public Vector showUserTypeAndUser();//连接查询员工信息及其种类
public Vector showUserTypeLikeType(String userType);//模糊查询用户种类
publicVectorfindStaffInfo(Stringstaffname);//模糊查找
publicintsaveStaff(StaffInfostaffInfo);//添加员工
publicintremoveStaff(Stringname);//根据姓名删除员工
publicintupdateStaff(StaffInfo2staffInfo2);//修改员工信息
publicVectorfindStaffSalary(Stringstaffname);//模糊查找
publicintupdateSalary(Stringdepart,doublesalary);//调整员工薪水信息
publicintaddRewardPunish(RewardPunishrp);//增加奖惩数据
publicintdeleteRewardPunish(RewardPunishrp);//删除奖惩数据
publicintupdateRewardPunish(intid,Stringdate,Stringtype,Stringreason,
intscore,Stringremark);//更新奖惩数据
publicVectorshowRewardPunish(intid);//显示奖惩数据
publicintSelectRewardPunish(RewardPunishrp);//选择奖惩数据
public Vector findDepart(String name);//根据部门名模糊查找
public Vector showDepartNumber(String name);//根据部门名统计各部门人数
6.4编码设计
开发环境的设置和建立:
下载并安装MyEclipse8.5,MySQL6.0;
程序设计时要注意的事项:
需加载与MySQL相对应的驱动包;
关键构件/插件的特点和使用:
JTable需要放在ScrollPane中,可与数据库中的表相对应,而且可以实现下拉滚动。
主要程序的代码设计及注释:
一.登录模块是用户登录进去进行相关操作的,如员工信息的增删改查等等。
(1)View层代码
loginTitle=newjavax.swing.JLabel();
jLabel1=newjavax.swing.JLabel();
jLabel2=newjavax.swing.JLabel();
uname=newjavax.swing.JTextField();
pwd=newjavax.swing.JPasswordField();
limit=newjavax.swing.JComboBox();
jLabel3=newjavax.swing.JLabel();
loginBtn=newjavax.swing.JButton();
registerBtn=newjavax.swing.JButton();
jLabel4=newjavax.swing.JLabel();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
setForeground(java.awt.Color.white);
setResizable(false);
setState
(1);
loginTitle.setFont(newjava.awt.Font("MicrosoftYaHeiUI",1,44));
loginTitle.setHorizontalAlignment(javax.swing.SwingConstants.CENTER);
loginTitle.setText("\u4eba\u4e8b\u5de5\u8d44\u7ba1\u7406\u7cfb\u7edf");
jLabel1.setText("\u7528\u6237\u540d");
jLabel2.setText("\u5bc6\u7801\uff1a");
//limit.setModel(javax.swing.DefaultComboBoxModel@187e702);
jLabel3.setText("\u6743\u9650\uff1a");
loginBtn.setText("\u767b\u9646");
(2)Action层
privatevoidregisterBtnActionPerformed(java.awt.event.ActionEventevt){
registerFramer=newregisterFrame();
r.setVisible(true);
}
privatevoidloginBtnMouseClicked(java.awt.event.MouseEventevt){
Stringname=this.uname.getText();
Stringpwd=this.pwd.getText();
Stringlimit=this.limit.getSelectedItem().toString();
inttype=0;
if("管理员".equals(limit)){
type=1;
usertype="管理员";
}else{
type=2;
usertype="普通员工";
}
Useruser=newUser(name,pwd,type);
Userflag=userService.login(user);
if(flag!
=null){
wusername=name;
wtype=limit;
oko=newok();
o.setVisible(true);
setVisible(false);
}else{
failf=newfail();
f.setVisible(true);
dispose();
}
}
(3)Dao数据交互层
@Override
publicUserlogin(Useruser){
//TODOAuto-generatedmethodstub
UserresultUser=null;
Stringsql="selectuser_no,user_name,user_pwd,user_type"+
"fromt_user"+
"whereuser_name='"+user.getUserName()+"'"+
"anduser_pwd='"+user.getUserPwd()+"'"+
"anduser_type="+user.getUserType()+"";
conn=JDBCUtil.getConnection();
try{
stmt=conn.createStatement();
rs=stmt.executeQuery(sql);
if(rs.next()){
resultUser=newUser();
resultUser.setUserNo(rs.getInt("user_no"));
resultUser.setUserName(rs.getString("user_name"));
resultUser.setUserPwd(rs.getString("user_pwd"));
resultUser.setUserType(rs.getInt("user_type"));
}
}catch(SQLExceptione){
e.printStackTrace();
}
finally{
JDBCUtil.closeResource(conn,psmt,stmt,rs);
}
returnresultUser;
}
二.人事管理模块设计及实现
对员工的相关资料及记录进行管理。
可在该模块对员工基本资料、奖惩记录、修改员工信息可实现对员工的调动、薪水记录进行修改。
当进入到人事管理子系统模块,再点击模糊查询。
删除员工按钮,会进入到下面的界面
其中的模糊查询代码如下
(1)view层
privatevoidinitComponents(){
jScrollPane1=newjavax.swing.JScrollPane();
jTable1=newjavax.swing.JTable();
jButton1=newjavax.swing.JButton();
jLabel1=newjavax.swing.JLabel();
jname=newjavax.swing.JTextField();
jButton2=newjavax.swing.JButton();
jButton3=newjavax.swing.JButton();
jLabel2=newjavax.swing.JLabel();
jButton4=newjavax.swing.JButton();
jLabel3=newjavax.swing.JLabel();
jLabel4=newjavax.swing.JLabel();
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
jTable1.setModel(newjavax.swing.table.DefaultTableModel(
newObject[][]{
},newString[]{"姓名","编号","部门编号","职称","性别","基本工资","电话号码","工号"}));
jScrollPane1.setViewportView(jTable1);
jButton1.setText("\u786e\u5b9a");
jButton1.addActionListener(newjava.awt.event.ActionListener(){
publicvoidactionPerformed(java.awt.event.ActionEventevt){
jButton1ActionPerformed(evt);
}
});jLabel1.setText("\u8bf7\u8f93\u5165\u59d3\u540d\uff0c\u652f\u6301\u6a21\u7cca\u67e5\u627e");
jname.setText(null);
jButton2.setText("\u9000\u51fa\u6a21\u7cca\u67e5\u627e");
jButton2.addActionListener(newjava.awt.event.ActionListener(){
publicvoidactionPerformed(java.awt.event.ActionEventevt){
jButton2ActionPerformed(evt);
}
});
jButton3.setText("\u5237\u65b0");
jButton3.addActionListener(newjava.awt.event.ActionListener(){
publicvoidactionPerformed(java.awt.event.ActionEventevt){
jButton3ActionPerformed(evt);
}
});
jLabel2.setText("\u5237\u65b0\u540e\u53ef\u7ee7\u7eed\u67e5\u627e");
jButton4.setText("\u5220\u9664\u6b64\u5458\u5de5");
jButton4.addActionListener(newjava.awt.event.ActionListener(){
publicvoidactionPerformed(java.awt.event.ActionEventevt){
jButton4ActionPerformed(evt);
}
});
jLabel3.setText("\u7a7a\u503c\u53ef\u67e5\u627e\u6240\u6709\u5458\u5de5");
jLabel4.setText("\u9700\u8981\u8f93\u5165\u5168\u540d\u53ef\u4ee5\u5220\u9664\u5458\u5de5");
publicvoidfindStaffName(JTablejTable,Stringname){
DefaultTableModelmodel=(DefaultTableModel)jTable.getModel();
model.setRowCount(0);
Vectorv=staffInfoDao.findStaffInfo(name);
for(inti=0;imodel.addRow((Vector)v.get(i));
}
}
(2)action层
privatevoidjButton1ActionPerformed(java.awt.event.ActionEventevt){
Stringname=jname.getText();
if(name!
=null){
staff.findStaffName(jTable1,name);
}else{
pleaseInputp=newpleaseInput();
p.setVisible(true);
}
}
(3)dao层
publicVectorfindStaffInfo(Stringstaffname){
Vectorlist=newVector();
Stringsql="select*"+"fromt_staff_info"
+"wherestaff_namelike'%"+staffname+"%'";
conn=JDBCUtil.getConnection();
try{
stmt=conn.createStatement();
rs=stmt.executeQuery(sql);
while(rs.next()){
VectorlistObject=newVector();
//listObject.add(new
//User(rs.getInt("id"),rs.getString("uname"),rs.getString("pwd")));
listObject.add(rs.getString("staff_name"));
listObject.add(rs.getInt("staff_id"));
listObject.add(rs.getInt("dept_no"));
listObject.add(rs.getString("staff_pos_name"));
listObject.add(rs.getString("staff_sex"));
listObject.add(rs.getInt("staff_baseSal"));
listObject.add(rs.getInt("staff_phoneNum"));
listObject.add(rs.getString("staff_workNum"));
list.add(listObject);
}
}catch(SQLExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}finally{
JDBCUtil.closeResource(conn,psmt,stmt,rs);
}
returnlist;
}
4.4工资管理模块设计与实现
在员工基本信息管理界面里可以对单个员工进行基本工资的修改,因而在面向人数较多的企业时,这种方式存在弊端,部门整体调薪操作可以对整个业绩高的部门进行整体调薪
(1)view层
privatevoidinitCo