Java人事管理系统

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

长沙理工大学城南学院《数据库系统应用》课程设计报告JAVA人事管理信息系统蒋映喆系别水利计通系专业计算机科学与技术班级计算机1001学号24学生姓名蒋映喆指导教师唐汇国课程成绩完成日期2012年10月13日课程设计成绩评定系别水利计通系专业计算机科学与技术班级计算机1001学号24学生姓名蒋映喆指导教师唐汇国课程成绩完成日期2012.10.13指导教师对学生在课程设计中的评价评分项目优良中及格不及格课程设计中的创造性成果学生掌握课程内容的程度课程设计完成情况课程设计动手能力文字表达学习态度规范要求课程设计论文的质量指导教师对课程设计的评定意见综合成绩指导教师签字年月日课程设计任务书城南学院水利计通系计算机科学与技术专业课程名称数据库系统应用课程设计时间2012~2013学年第1学期1~2周学生姓名蒋映喆指导老师唐汇国题目JAVA人事管理系统——公司人员管理实现主要内容:本课程设计主要完成一个公司人事管理信息系统,本系统分为三个大模块,两人完成,三个模块分别为:1.应用层界面模块。其中包括登陆界面与主要管理界面的实现。2.系统数据库模块。这里主要实现对数据库的创建。3.程序消息响应模块。主要实现程序的运行,连接数据库等功能。要求:(1)要求能独立地运用程序语言和数据库方面知识,编制一个功能简单的小型信息模拟系统。(2)学生按要求编写课程设计报告书,能正确阐述设计和实验结果。(3)通过课程设计培养学生严谨的科学态度,认真的工作作风和团队协作精神。(4)学生应抱着严谨认真的态度积极投入到课程设计过程中。应当提交的文件:(1)课程设计报告。(2)课程设计附件(源程序、各类图纸、实验数据、运行截图等)。JAVA人事管理信息系统学生姓名:蒋映喆、阳坚指导老师:唐汇国摘要在当前的信息化管理浪潮下,我国的人事管理模式也由传统的手工业务办理模式逐渐转向信息化,现代化的高效管理模式。结合人事办公管理的实际情况和实践操作,研发的新一代人事管理系统,使一直沿袭传统办公模式而产生的管理效率较低,经营管理水平相对滞后等现象得改善已经成为各个单位的必然需求;为了提高人事办公行业整体的科技含量与管理效率,加快人事行业的信息化建设;为了提高公司的管理水平,他们急需一套安全可靠的人事管理系统,所以我与同学阳坚一起开发了这套人事管理系统。关键词JAVA;人事管理系统;oracle1开发环境与项目组介绍1.1硬件环境1、内存:256MB以上2、CPU:酷睿i5M4601.2软件环境1、操作系统:MicrosoftWindowsXP2、数据库系统:Oracle+PL/SQL3、开发工具包:JDKVersion1.4.24、开发软件:Eclipse1.3项目组成员1、蒋映喆:主要负责程序的界面与消息响应。2、阳坚:负责数据库的创建与优化。2系统设计2.1应用程序界面设计由于公司人事管理并非普通员工管理、系统必须具有较高的安全性,只有具有管理员身份的用户才能允许对员工信息的编辑,修改等权限,所以我们必须为管理者设定一个登陆框,通过登录才能进入主界面实现对员工信息的操作,这样即使管理者不在电脑旁别人也无法私自修改员工信息,大大的增加了系统的安全可靠性。进入主界面以后,管理者能实现对员工的档案进行管理,可以查看、添加、修改、删除员工信息等。同时主界面也必须实现管理者的用户管理,用于修改当前密码等。同时系统要具有较高的适应性,能够适应应用要求的变化与修改,具有灵活可扩充性。程序在性能上必须可以方便快捷有效地完成编辑、查询等地各项操作,录入数据合法性校验程序高,查询速度快。保证信息的正确及时更新,并降低信息访问的成本。操作方便可大大提高工作效率。程序主要流程图如图1所示:图1程序流程图2.2数据库的选择OracleDatabase,又名OracleRDBMS,或简称Oracle。是甲骨文公司提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器端(Client/Server)或B/S体系结构的数据库之一。作为一个通用的数据库系统,它具有完整的数据管理功能;作为一个关系数据库,它是一个完备关系的产品。所以在此课程设计中,我和阳坚同学采用Oracle作为我们的开发数据库来开发这个人事管理系统。2.3系统数据实体结构描述管理员信息表(Manager):用以登陆对员工信息的管理。具体设计结构如表1所示:表1管理者信息表功能名称:管理者信息表(Manager)数据元素数据采集方式说明Name人工采集主键,必须输入SSID人工采集非空,必须输入员工信息表(worker):用以记录员工基本信息,具体设计如表2所示:表2员工信息表功能名称:员工信息表(worker)数据元素数据采集方式说明nId人工采集主键,必须输入Name人工采集非空,必须输入Job人工采集允许空Sal人工采集允许空由于某些特定的公司拥有一些特殊职业,所以我们在工作与工资这两栏设置允许空,方便管理者管理。3系统详细设计3.1系统工作原理在登陆框处使用代码连接Manager数据库,采用JDBC方法连接数据库,从Edit框获取用户输入的用户名与密码与Manager表中数据对比,如果为数据库中的数据则允许登陆进行员工管理,若非数据库中的数据则报错。在主界面处分别连接worker与Manager两个数据库进行不同操作,如修改密码时则连接Manager,对员工进行操作则连接worker进行数据库操作,从而达到人事管理系统的需求。由于Oracle为C/S或者B/S模式的数据库,B/S模式即流浪器/服务器模式,是一种从传统的的二层C/S(客户端/服务端)模式发展起来的新的网络结构模式,其本质是三层结构的C/S模式,安全性与方便性高。所以我们整个员工管理系统也采用C/S或者B/S模式的系统构架,我们的数据库放在公司服务器上,管理者客户端通过代码远程连接至数据库服务器,从而获取数据并修改数据。而我们的数据库处在服务器的防火墙之后,更增加了数据的可靠性与安全性。应用界面的工作原理如图2所示:图2应用界面工作原理3.2数据库详细设计要操作数据库的方法有很多,这里我们采用方便的PL/SQL来操作Oracle数据库,在系统服务中打开Oracle数据库的Server之后,我们使用默认的scott账号登陆并创建表单。Manager表单的创建:CreateTableManager(Namevarchar(20),SSIDvarchar(20)NotNULL,PRIMARYKEY(Name))Worcker表单的创建:CreateTableworker(NIDVARCHAR2(4),NAMEVARCHAR2(20)NotNULL,JOBVARCHAR2(20),SALNUMBER(8,2),PRIMARYKEY(NID))在表单创建后用Insertinto语句向两个表单中分别插入数据,因为数据量比较大,我这就不一一赘述我的数据了,插入数据如图3所示:图3两个表中所插入的数据3.3程序界面详细设计界面设计我们采用了网格布局方法,使得界面简洁美观易于操作。界面主要分为登陆框界面与主程序界面,主界面使用了一个Table控件分割员工管理与用户管理来方便管理员管理,同时也为程序节省了占用的资源。3.4程序消息响应详细设计程序的消息响应主要为登陆框的登录响应与主程序的添加删除查询等Button的KeyDown响应,只要为Button添加成员函数addActionLisener并在函数内书写响应代码即可,如登陆框的消息响应如下:JButtonokBtn=newJButton(登陆);//为登陆按钮添加事件okBtn.addActionListener(newActionListener(){publicvoidactionPerformed(ActionEvente){//获取用户在文本框中输入的值,去掉前后的空格,匿名内部类访问外部成员,外部成员必须使用final修饰Stringname=txt_name.getText().trim();Stringpwd=txt_pwd.getText().trim();LoginSqlu=newLoginSql();intflag=1;try{flag=u.findByName(name,pwd);//System.out.println(flag);}catch(Exceptione1){//TODOAuto-generatedcatchblock//e1.printStackTrace();}//判断用户是否合法//System.out.println(flag);if(flag==1){//System.out.println(登陆成功。。。。);if(JOptionPane.showConfirmDialog(loginFrame,登陆成功!,提示,JOptionPane.YES_NO_OPTION,JOptionPane.QUESTION_MESSAGE)==JOptionPane.YES_OPTION){loginFrame.setVisible(false);newMainFrame();}}else{JOptionPane.showConfirmDialog(loginFrame,用户名或者密码错误!,错误通知,0);}}});3.5连接数据库详细设计使用Java连接Oracle数据库需要驱动库,因此先Import从网上下载的JavaOracle驱动库classes.jar文件,如图4所示:图4工程文件目录使用Java连接Oracle数据库的步骤:1、加载数据库驱动:Class.forName(oracle.jdbc.driver.OracleDriver);2、连接数据库:Connectionconnection=DriverManager.getConnection(jdbc:oracle:thin:@127.0.0.1:1521:WAIT,scott,tiger);采用本机回路IP默认本机为主机端口为配置Oracle时所填写的1521,主机名:wait,登录数据库账户与密码:scott,tiger;3、查询数据库:ResultSetrSet=statement.executeQuery(select*fromManager);在完成以上三步以后我们就可以通过ResultSet的对象rSet.next来读取数据库中的数据了。4测试和运行结果截图4.1登录界面图5登录界面运行截图4.2主程序界面图6主程序界面图7添加新员工界面图8删除提示图9修改与查询后的界面图10管理人员修改密码界面5结束语在这次课程设计中,小组每个成员分工明确,互相帮助,为设计的开发成功营造了良好的氛围。在日后的工作与学习中,我们应继续发扬这样的工作精神。通过这次的课程设计,我们学习到了整个开发软件的标准流程与数据库在实际操作中的应用,以及在开发过程中团队合作分工的重要性。更能深刻地理解开发软件的相关知识,锻炼了开发能力,知识得到了很大的拓展。在进行分析、设计、编码、调试、维护这几部分的工作的时候,最核心的就是文档的编写。文档的编写有助于我们整理思路不做无头苍蝇,同样也便于团队交流与日后维护的参考。通过这次课程设计,我学习到了不少的知识,如Java、Oracle的使用,将对我在今后的软件开发过程中起到极大的作用。其实开发软件也可以用到我们现实生活中来,这次课程设计改变了我以往的思维方式,以前我总认为做软件就是一个人对着电脑无限地敲打代码,现在明白了团队的分工、合作的重要性,团队的力量要远远超过个人的力量!附录1程序源代码1、LoginFrame.javapackagecom.JiangYzh;importjava.awt.BorderLayout;importjava.awt.Color;importjava.awt.Component;importjava.awt.Container;importjava.awt.Font;importjava.awt.GridBagConstraints;importjava

1 / 42
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功