【毕业设计】基于web的人事工资管理系统的设计与实现_第1页
【毕业设计】基于web的人事工资管理系统的设计与实现_第2页
【毕业设计】基于web的人事工资管理系统的设计与实现_第3页
【毕业设计】基于web的人事工资管理系统的设计与实现_第4页
【毕业设计】基于web的人事工资管理系统的设计与实现_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

基于WEB的人事工资管理系统的设计与实现代写论文Q球296145855目录摘要关键字1、前言11人事工资管理系统研究的背景和意义12人事工资管理系统研究的现状2、相关技术介绍21ASPNET20技术介绍211ASPNET20框架结构212ASPNET20工作原理213ASPNET20的特点22NHIBERNATE框架介绍23ASPNETAJAX介绍3、工资管理系统的分析和建模31系统概述32系统目标和设计要求33工资管理系统需求分析331员工基本信息管理332工程基本信息管理333材料信息和开销管理334员工工作记录管理335员工工资管理336权限管理34财务管理系统体系结构建模341系统用例分析与设计342系统类图分析与设计4、工资管理系统的总体设计和实现41系统总体设计思想42系统体系结构模型43系统开发环境44系统数据库设计441数据库表设计原则442数据库表的设计443重要数据库表之间的关系45工资管理系统的实现总结参考文献致谢基于WEB的工资管理系统的设计与实现摘要传统的工资管理系统通常采用固定的工资计算公式和固定的工资项目,难于适应市场经济条件下工资政策和工资制度的变化。现有的柔性工资结构的工资管理系统虽然可以自定义帐套、工资项目和计算公式等,但往往操作复杂,难于在基层客户中推广使用。随着计算机及网络在教学领域的不断应用,WEB网上教材管理系统也得到了不断的发展和应用,作为网络教育支持平台中十分重要的组成部分,是网络教育教学反馈、质量评估的有效手段。本文论述了教材管理系统的研究意义,重点讨论了教材管理系统的设计与实现。该系统采用B/S模式,三层软件体系结构,运用ASPNET动态网页语言、JAVASCRIPT脚本语言、CSSDIV及SQLSERVER2000和VISUALSTUDIO2008等相关软件技术,实现了教材科管理端的系统设置、计划审批及教材审核、入库管理、出库管理、库存管理、教材费结算,院系用户端的计划编报、订单及教材发放单打印、本单位教材费查询,学生用户端个人教材费查询等功能。教材管理的全部工作都可通过该系统在线完成,所有数据实时共享。关键词教材管理系统三层架构B/S模式1、前言传统的工资管理系统通常采用固定的工资计算公式和固定的工资项目,难于适应市场经济条件下工资政策和工资制度的变化。现有的柔性工资结构的工资管理系统虽然可以自定义帐套、工资项目和计算公式等,但往往操作复杂,难于在基层客户中推广使用。本文设计实现了一个基于WEB的人事工资管理系统。首先对项目背景及工资系统的结构进行了简要分析,在此基础上使用RAT1ONALROSE给出系统的设计,并使用ASP实现了该BROWSER/SERVER模式的工资管理系统。该工资管理系统的功能包括管理部信息、人员信息等工资管理系统的基础资料,设置工资帐套、工资项目,同时还建立帐套与工资项目的对应关系,为工资项目设置计算公式,单独设置个人所得税计算公式,计算人员工资包括根据公式计算工资项目的值、计算个人所得税,为方便用户的使用还设置了浏览、打印员工的工资表和工资条,对一定时间段的工资记录进行结帐封存,统计分析人员或者某个部门的某段时间内的工资记录,查找人员工资内容等功能。论文重点阐述了工资计算和公式计算功能的设计与实现。在本论文中使用分治法对复杂的公式计算功能进行实现,在计算人员工资时,系统会根据人员所属的帐套,对具有计算公式的工资项目,自动调用公式计算函数,计算该工资项目的值,最终生成个人工资记录。因为在不同的帐套中相同的工资项目可以设置不同的计算公式,所以系统是具有灵活性的,同时,这种设置也提高了工作人员的工作效率。11人事工资管理系统研究的背景和意义在当今知识经济时代,人才成为日益关注的、决定企事业单位兴衰的主要元素之一。人力资源管理工作也成为企事业单位管理工作的一个重要组成部分。随着企事业单位人力资源的日益庞大、复杂程度逐渐增强,以前简单的几段文字、几张报表的人机作坊再也无法适应如今的人力资源管理工作了,取代的是运用各个领域的知识,结合计算机科学与技术开发的人力资源管理系统,科学合理地管理企事业人事信息及扩充的人力资源信息。从功能上讲,国内目前的人力资源管理软件大多还处于传统的人事管理系统阶段。它们都只有人员和机构档案的管理、简单的考勤管理和工资管理,缺少作为人力资源管理软件所必需的人员招聘与任用、培训与开发、绩效考核、员工职业生涯规划、分析和决策支持等功能。国外系统虽然业务流程非常清晰,管理非常规范,但往往也是不够灵活,通用性不强。再者,目前市场上的人力资源管理软件很少是为电力企业开发的,针对电力行业人力资源管理工作特点开发的人力资源管理系统是少之又少,更不用说买到能适用于人力资源管理的软件了。目前,大多数人力资源管理系统还只是FOXBASE的简单升级版,处于条块分割,各自为政,整天忙于低级的重复劳动中,浪费了大量人力劳力。因此,为了更好的满足人力资源管理的实际需要,减少大量繁杂的人力资源管理事务,切实提高人力资源管理效率,需要开发一个适用于某个公司行业特点的人力资源管理系统,并能方便地进行二次开发,以适用于不同的中小企业。近年来,随着INTERNET和INTRANET/EXTRANET的快速增长,基于WEB的应用系统的开发备受关注。但目前的人力资源管理软件大多是单机系统下的应用,这样对信息的管理者和使用者来说会有诸多不便。并且由于开发工具本身的限制,对网络功能的支持程度不是很强,为以后软件升级到互联网带来了麻烦。因此,有必要开发一个基于网络的人力资源管理系统,能在网络环境下实现数据的编辑、修改、删除、查询、打印等功能。12人事工资管理系统研究的现状虽然人力资源管理软件在中国已有超过十年的发展历程,但由于人力资源管理整个大环境的观念和管理相对国外滞后,因而中国的人力资源管理软件尚处于产品不规范、厂商过于混杂、企业未领会人力资源管理软件真正价值的“初级阶段”。目前国内人力资源管理软件主要有金益康公司的金益康人力资源管理信息系统YKHRMIS、益康世纪的HRP2000、实达朗新的人事管理系统、上海广电软件信息有限公司的汇智人力资源管理系统、上海嘉扬信息系统公司的嘉扬人力资源管理系统POWER2000、汇林科软件深圳有限公司的人力资源管理系统。就目前的市场来看,人力资源管理软件竞争还不算很激烈。这些产品最初多是人事管理系统,作为人力资源管理系统大多是在1999年推出的,现在还都处在市场开拓阶段。国外人力资源管理软件具有操作简单、界面友好的特点。业务流程非常清晰,管理非常规范。从技术来看均采用ODCB技术,支持CL1ENT/SERVER结构。但国外系统往往不够灵活,通用性不强,尤其有些方面不符合中国的习惯。2、相关技术介绍本章概述本章主要对系统中使用到的主要技术进行了介绍,包括ASPNET20框架结构、工作原理以及特点,NHIBERNATE框架体系结构和ASPNETAJAX框架。21ASPNET20技术介绍自MICROSOFT公司于2000年6月在“论坛2000“上向全球正式推出MICROSOFTNET以来,MICROSOFTNET就成为整个IT业界极为关注的话题,越来越多的应用已经开始建立在NET这种新的体系结构之上,并迅速成为信息化应用的潮流于方向3。211ASPNET20框架结构ASPNET20框架是继ACTIVEX技术之后,于2000年推出的用于构建新一代INTERNET集成服务平台的最新框架,这种集成服务平台允许各种系统环境下的应用程序通过因特网进行通信和共享数据。目前,因特网服务器平台亟特解决的重要问题是系统间的互通性问题,一些相关协议如XML(EXTENSIBLEMARKUPLANGUAGE,可扩展标记语言)、SOAP(SIMPLEOBJECTACCESSPROTOCOL,简单对象访问协议)等,NET平台将这些协议提供支持,其意义可与当年WINDOWS平台推出的意义相提并论,微软公司将其称为“NET战略”。也就是说,NET的最终目的就是让用户在任何地方、任何时间,利用任何设备都能访问所需的信息、文件和程序。用户不需要知道这些文件放在什么地方,只需要发出请求,然后只管接收即可,而所有后台的复杂性是完全屏蔽起来的。同时,对于开发人员来说,更容易建立WEB应用程序和WEB服务,进一步简化对应用程序的开发。ASPNET20的三层结构如图21所示。图21ASPNET的三层结构UI层负责与用户交互,接收用户的输入并将服务器端传来的数据呈现给客户。业务逻辑层负UI层客户端WEB浏览器业务逻辑层WEB表单XMLWEB服务组件服务ADONETRDBMS责接收浏览器传来的请求并将请求传给数据层,同时将请求处理结果发给浏览器。它由WEB表单、XMLWEB服务和组件服务组成。其中WEB表单是ASPNET应用程序的核心所在,它是向客户呈现数据和信息的基础,也是响应和处理客户与显示的WEB表单交互生成的信息和数据的基础。数据层是通过ADONET操纵数据为事务逻辑层提供数据服务,如存储数据操作结果、返回数据检索结果等。NET框架具有两个主要组件公共语言运行库和NETFRAMEWORK类库。公共语言运行库是NET框架的基础。从层次上来看,NET框架包括三个主要组成部分公共语言运行时(COMMONLANGUAGERUNTIME,CLR或称公共语言运行库)、服务框架(SERVICESFRAMEWORK)和两类应用模板。两类应用模板包括传统的WINDOWS应用程序模板(WINDOWS表单)和基于ASPNET的面向WEB的应用程序模板(WEB表单和WEB服务)4。212ASPNET20工作原理ASPNET的工作原理是首先,有一个HTTP请求发送到WEB服务器要求访问一个WEB网页。WEB服务器通过分析客户的HTTP请求来定位所请求网页的位置。如果所请求的网页的文件名的后缀是ASPX,那么就把这个文件传送到ASPNET_ISAPIDLL进行处理,由ASPNET_ISAPIDLL把ASPNET代码提交给CLR。如果以前没有执行过这个程序,那么就由CLR编译并执行,得到纯HTML结果;如果已经执行过这个程序,那么就直接执行编译好的程序并得到纯HTML结果。最后把这些纯HTML结果传回浏览器作为HTTP响应。浏览器收到这个响应之后,就可以显示WEB网页。213ASPNET20的特点ASPNET20与以前的WEB开发模型ASP相比,ASPNET具有以下突出的特点。(1)优良的性能ASPNET代码不再是解释型的脚本,而是运行于服务器端经过已经编译好的公共语言运行库CLR代码。同时,ASPNET可利用早期绑定、实时编译、本机优化和缓存服务来提高程序执行的性能,因此,大大提高了ASPNET程序的执行效率。(2)强大的开发工具支持ASPNET应用程序可用微软公司最新产品VISUALSTUDIO2008进行开发,VISUALSTUDIONET提供了强大、高效的NET应用程序的集成开发环境,支持所见即所得、控件拖放和自动部署等。使用VISUALSTUDIONET进行ASPNET应用开发,可大大提高程序开发效率,并且简化程序的部署和维护工作。(3)多种语言支持目前ASPNET支持完全面向对象的C、VISUALBASICNET和JSCRIPTNET等ASPNET是语言独立化的LANGUAGEINDEPENDENT,即无论使用何种语言编写程序,都将被编译为中间语言。所以,程序开发人员可以选择一种自认为最适合的语言来编写程序,或者用多种语言编写程序。(4)自定义性和扩展性ASPNET设计是考虑了让开发人员可以在代码中自己定义“PLUGIN”模块,即ASPNET可以加入自己定义的任何组件。实际上,可以用自己编写的自定义组件扩展或替换ASPNET运行库的任何子组件。(5)安全性ASPNET借助内置的WINDOWS身份验证和基于每个应用程序的配置,可以保证应用是安全的。(6)清晰的程序结构ASPNET使用事件驱动和数据绑定的开发方式,将程序代码和用户界面彻底分离,具有清晰的结构。另外,可以使用CODEBEHIND方式将程序代码和用户界面标记分离在不同的文件中,使程序的可读性更强。另外,ASPNET对ASP应用程序有着很高的兼容性,这保证了将ASP程序迁移到ASPNET环境时,只稍做改动或不用修改仍能正常运行。22ASPNETAJAX介绍MICROSOFTASPNETAJAX是MICROSOFT公司对AJAX技术的完美封装。它能使你已快速的创建包含丰富用户体验的用户界面的WEB页面,提供加入了跨浏览器的ECMASCRIPTJAVASCRIPT和动态HTMLDHTML技术的客户端脚本,并与基于服务器的ASPNET20平台进行了集成。它还对JAVASCRIPT进行了非常巧妙的面向对象方面的扩展,以提供对客户端面向对象编程的支持提供了与ASPNET紧密结合的客户端/服务器端组件、类型的自动转换自动为客户端暴露服务器端的代码的方法为远程WEBSERVICE提供本地客户端代理等许多优美的功能。使用ASPNETAJAX,可以提高应用程序的用户体验和效率。ASPNETAJAX由客户端脚本库和服务器端组件缓存,以提供一个健壮的开发框架。除了ASPNETAJAX以外,还可以使用ASPNETAJAXCONTROLTOOLKIT和由社区提供的ASPNETAJAXFUTURES的特性。23NHIBERNATE框架介绍NHIBERNATE是一个面向NET环境的对象/关系数据库映射工具。对象/关系数据库映射(OBJECT/RELATIONALMAPPING,ORM)这个术语表示一种技术,用来把对象模型表示的对象映射到基于SQL的关系模型数据结构中去。NHIBERNATE不仅仅管理NET类到数据库表的映射(包括NET数据类型到SQL数据类型的映射),还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和ADONET处理数据的时间。NHIBERNATE的目标主要是用于与数据持久化相关的编程任务,能够使开发人员从原来枯燥的SQL语句的编写中解放出来,解放出来的精力可以让开发人员投入到业务逻辑的实现上。对于以数据为中心的程序,开发人员往往是在数据库中使用存储过程来实现商业逻辑,这种情况下NHIBERNATE可能不是最好的解决方案,但对于那些基于NET,并且能够实现OO业务模型和商业逻辑的中间层应用,NHIBERNATE是最有用的。NHIBERNATE可以帮助用户消除或者包装那些针对特定厂商的SQL代码,并且帮用户把结果集从表格式的表示形式转换成一系列的对象。1NHIBERNATE体系结构NHIBERNATE体系结构如图21所示。它体现了NHIBERNATE如何使用数据库和配置文件数据来为应用程序提供持久化服务(和持久化的对象)。图21NHIBERNATE体系结构在NHIBERNATE全面解决体系中,NHIBERNATE运行时体系结构的细节如图22所示。图22NHIBERNATE体系结构SESSIONFACTORYNHIBERNATEISESSIONFACTORY它是SESSION的工厂,是CONNECTIONPROVIDER的客户。可以持有一个可选的(第二级)数据缓存,可以在进程级别或集群级别保存的可以在事物中重用的数据。会话(NHIBERNATEISESSION)单线程,生命期较短的对象,代表应用程序和持久化层之间的一次对话。封装了一个ADONET连接,也是TRANSACTION的工厂。保存有必需的(第一级)持久化对象的缓存,用于遍历对象图,或者通过标识符查找对象。持久化对象(PERSISTENT)及其集合(COLLECTIONS)生命期较短的单线程的对象,包含了持久化状态和商业功能。这些可能是普通的对象,唯一特别的是现在从属于且仅从属于一个SESSION。一旦SESSION被关闭,它们都将从SESSION中取消联系,可以在任何程序层自由使用(比如,直接作为传送到表现层的DTO,数据传输对象)。临时对象(TRANSIENTOBJECT)及其集合(COLLECTION)目前没有从属于一个SESSION的持久化类的实例。这些可能是刚刚被程序实例化,还没有来得及被持久化,或者是被一个已经关闭的SESSION实例化。事务TRANSACTIONNHIBERNATEITRANSACTION(可选)单线程,生命期较短的对象,应用程序用其来表示一批工作的原子操作,它是底层的ADONET事务的抽象。一个SESSION在某些情况下可能跨越多个TRANSACTION事务。CONNECTIONPROVIDER(NHIBERNATECONNECTIONCONNECTIONPROVIDER)(可选)ADONET连接的工厂。从底层的IDBCONNECTION抽象而来。对应用程序不可见,但可以被开发者扩展/实现。TRANSACTIONFACTORY(NETSFHIBERNATETRANSACTIONFACTORY)(可选)事务实例的工厂。对应用程序不可见,但可以被开发者扩展/实现。2持久化类持久化类是应用程序用来解决商业问题的类(比如,在电子交易程序中的CUSTOMER和ORDER)。持久化类是暂时存在的,实例会被持久性保存于数据库中。3NHIBERNATE映射对象和关系数据库之间的映射是用一个XML文档(XMLDOCUMENT)来定义的。这个映射文档被设计为易读的,并且可以手工修改。映射语言是以NET为中心的,意味着映射是按照持久化类的定义来创建的,而非表的定义。在HIBERNATE中XML映射文档可以手动定义,也有一些工具来辅助生成,包括XDOCLET、MIDDLEGEN和ANDROMDA,但是在NHIBERNATE文档中并没有上述的辅助工具,不过可以采用MYGENERATION这样的代码生成工具来生成XML配置文档。3、工资管理系统的分析和建模本章概述软件系统的需求分析是软件开发过程中极其重要的一步,需求分析的好坏直接影响着所开发的软件系统是否合理,是否符合用户的需要。需求分析过程通常是从软件系统功能需求的调查研究入手,最终形成能够全面反映各部分功能要求的描述文档。软件需求分析的目标是深入描述软件的功能和性能,确定软件设计的约束和软件同其它系统元素的接口细节,定义软件的其它有效性需求。31系统概述32系统目标和设计要求本系统实现的目标是借助于INTERNET,使员工工资管理工作中的各个环节达到自动化、规范化、工资管理由复杂、繁琐转为简单快捷化。从而达到在减轻财务人员的工作量的同时,又方便、快捷、准确的对员工资进行管理。系统应具有以下设计要求1、实现对员工工资的全面管理工资管理系统是一个综合性的人机交互系统,他专门针对农村工程承包的特殊流程和业务要求进行数据组织处理和信息调控,代替业务人员进行烦琐和重复性的工作。使各级用户能够根据本系统顺利完成员工工资管理的有关工作。2、扩充和维护容易该系统采用了面向对象的开发思想,采用基于简单工厂的三层架构模式,可以降低层与层之间的依赖,利于各层逻辑的复用,同时数据访问层采用了NHIBERNATE框架,有利于数据库的移植操作。另外,系统使用了运行日志管理,可以根据日志记录很容易的找出系统出现异常的原因,从而使得系统的维护变得简单。3、数据打印和导出方便该系统使用了微软的RDLC报表控件,查询出要打印的数据后,一键就可以实现打印或者导出,弥补了原有系统需要复制放到WORD里面再打印的缺陷。33工资管理系统需求分析本工资管理系统包括员工信息管理、工程信息管理、材料信息选购、材料购置开销管理、员工工作记录管理、员工工资支取管理、员工工资结算和盈亏统计管理。工资管理系统结构图如图31所示图31工资管理系统结构图331员工基本信息管理员工基本信息管理模块是对员工基本信息进行管理,包括添加员工基本信息、修改员工基本信息、删除员工基本信息。员工基本信息包括员工姓名、性别、家庭住址、联系电话、电子邮件等。332工程基本信息管理工程基本信息管理模块是对工程基本信息进行管理,包括添加工程基本信息、修改工程基本信息、删除工程基本信息。工程基本信息包括工程名、所有人、投资额、动工日前、完工日期等。333材料信息和开销管理本模块主要是针对购买器材费用的管理材料基本信息管理和材料购买开销的增、删、改管理。材料基本信息包括材料名称,价格等,购买材料记录信息包括购买数量、购买材料名称、购买人、购买时间等。334员工工作记录管理员工工作记录模块是对员工工作情况进行记录。包括添加员工工作记录、修改员工工作记录、删除员工工作记录。员工工作记录信息包括员工编号、工程编号、工作类型、日工资等信息。335员工工资管理员工工资管理包括员工工资支取管理和工资结算管理。工资支取管理是对员工所支取的钱数进行管理。工资结算是根据员工所作的工作金额和支取金额计算员工最终所得工资。336权限管理该系统主要是针对农村个体户建筑工程项目的工资管理。只涉及员工和管理员。员工可以查询自己所作工作记录情况和工资支取情况,并且可以打印账单。34工资管理系统体系结构建模341系统用例分析与设计在工资管理系统中,参与的用户主要有两类管理员和员工。他们有着不同的权限,完成不同的功能。(1)该系统管理员总的用例图如图32所示亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏图32工资管理系统管理员总用例图(2)该系统员工用例图如图33所示亏亏亏亏亏亏亏亏亏亏亏亏亏图33工资管理系统员工用例图(3)该系统管理员和员工关系用例图如图34所示亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏亏图34工资管理系统员工用例图342系统类图分析与设计UML的静态建模机制包括用例模型、类和对象模型。用例模型用于需求分析阶段,它的建立是系统开发者和用户反复讨论的结果,表明了开发者和用户对需求规格达成的共识。UML中类有三种主要的类型边界类、控制类和实体类。引入边界类、控制类及实体类的概念有助于分析和设计人员确定系统中的类。边界类位于系统与外界的交界处,窗体、报表、以及表示通讯协议的类、直接与外部设备交互的类、直接与外部系统交互的类等都是边界类。通过用例图可以确定需要的边界类,每个ACTOR/USECASE对至少要一个边界类,但并非每个ACTOR/USECASE对要唯一的边界类。实体类保存要放进持久存储体的信息。持久存储体就是数据库、文件等可以永久存储数据的介质。实体类可以通过事件流和交互图发现。通常每个实体类在数据库中有相应的表,实体类中的属性对应数据库表中的字段。控制类是控制其他类工作的类。每个用例通常有一个控制类,控制用例中的事件顺序,控制类也可以在多个用例间共用。其他类并不向控制类发送很多消息,而是由控制类发出很多消息。通过功能和用例分析,工资管理系统的实体类包括工程(PROJECT)、员工EMPLOYEE、工作记录(WORKRECORD)、工资领取(WAGE)、材料(MATERIALS)、材料开销(MATERIALSCOST)、用户USERS。一个工程可以有多个员工工作,一个员工可以有多条工作记录,可以多次支取工资。一件材料可以有多条材料开销记录。系统静态类图如图所示。4、工资系统的总体设计本章概述本章对系统的总体设计思想,系统体系结构模型设计,系统开发环境和数据库设计进行了详细的描述。41系统总体设计思想本系统是为了实现工资管理的自动化和网络化,提高工资管理的工作效率而设计的。其总体设计思路为1、系统采用BS模式以目前的技术看,局域网建立B/S结构的网络应用,并通过INTERNET模式下数据库应用,相对易于把握、成本也是较低的。它是一次性到位的开发,能实现不同的人员,从不同的地点,以不同的接入方式(比如LAN,WAN,INTERNET等)访问和操作共同的数据库;它能有效地保护数据平台和管理访问权限,服务器数据库也很安全。这样就大大简化了客户端电脑载荷,减轻了系统维护与升级的成本和工作量,降低了用户的总体成本。2、采用面向对象的设计思想本系统将采用面向对象的思想进行系统的开发,运用三层架构,方便系统开发,降低层与层之间的依赖,有利于标准化和逻辑的复用。3、数据库可移植性本系统数据持久层采用NHIBERNATE框架,它把表映射成对象,通过操作对象才操作数据,因为NHIBERNATE框架已经区分了数据库操作的不同,从而有利于数据库的移植操作。4、界面美观,操作简单,操作人性化本系统将采用ASPNETAJAX技术和JAVASCRIPT技术,比如局部刷新、智能提示等技术,给用户友好的操作提示信息,使操作非常人性化,且界面美观,管理将更简单方便。42系统体系结构模型工资管理系统采用的是基于简单工厂的三层体系B/S结构。从下至上分别为数据访问层(DATAACCESSLAYER)、业务逻辑层(BUSINESSLOGICLAYER)、表示层(UI),系统体系结构模型如图所示。图41系统体系结构模型数据访问层有时候也称为是持久层,其功能主要是负责数据库的访问。简单的说法就是实现对数据表的SELECT,INSERT,UPDATE,DELETE的操作。在数据访问层(DAL)中,采用了NHIBERNATE框架,增强了数据库的可移植性。业务逻辑层系统的的核心模块,它包含了整个系统的核心业务。在业务逻辑层中,不能直接访问数据库,而必须通过数据访问层。表示层是系统的UI部分,负责使用者与整个系统的交互。在这一层中,理想的状态是不应包括系统的业务逻辑。表示层中的逻辑代码,仅与界面元素有关。43系统开发环境1、开发工具VISUALSTUDIO2008运用VS2008开发平台能够快速构建应用程序,良好的代码智能提示功能,提供了丰富的可视化组件以及ASPNETAJAX框架,能大大提高开发效率。2、程序设计语言ASPNETC3、数据库SQLSERVER2000MICROSOFTSQLSERVER2000能提供超大型系统所需的数据库服务点,而且可以防止多个用户试图同时更新相同的数据。SQLSERVER2000还在多个用户之间有效地分配可用资源,比如内存、网络带宽和磁盘I/O。相对MYSQL、ORACLE、SYBASEDB2,SQLSERVER性价比最好,和NET集成比较好,很合适用于WINDOWS应用的后台数据库,管理和开发入手都比较方便。强大的数据查询和管理功能,对SQL的支持,方便对查询结果进行验证,支持事务处理,权限的管理和数据库的备份和还原功能。4、运行环境服务器端WINDOWSSERVER2003/WINDWOS2000/XP客户端WINDOWS2000/XP等。44系统数据库设计441数据库表设计原则在设计数据库时,主要从以下两个方面考虑(1)数据库必须层次分明,布局合理。(2)具有良好的数据库结构,易于维护,易于理解,效率较高。主要是主键的设置采用自增的形式,其它表关联时,只存储该自增的ID,方便进行更新操作时,不需要更新与该表关联的表的信息。(3)数据冗余度。在设计数据库的时候,一方面要尽可能地减小冗余度,减小存储空间的占用,降低数据一致性问题发生的可能性;另一方面,还要考虑适当的冗余,以提高运行速度和降低开发难度。442数据库表的设计根据系统需求分析和系统建模,设计出系统数据库BOOKMANAGER基本数据表。系统的主要数据表和功能描述如下。(1)教材基本信息表B_BOOKINFO是教材基本信息表,用于记录教材ISBN、书名、出版社、数量等基本信息,以ID作为主键。其字段如表41所示。表41教材基本信息表(B_BOOKINFO)序号列名数据类型长度说明1IDINT4表ID自增2ISBNVARCHAR20书ISBN号3BOOKNAMEVARCHAR50书名4PUBLISHVARCHAR30出版社5AUTHORVARCHAR36作者6VERSIONVARCHAR10版本号7PRICENUMERIC9单价8NUMINT4数量(2)教材计划表B_BOOKPLAN是教材教材计划,用于记录学年、学期、班级、订购数量等基本信息,以ID作为主键,BOOKINFOID关联教材基本信息表。其字段如表42所示。表42教材计划表(B_BOOKPLAN)序号列名数据类型长度说明1IDINT4表ID2CAMPUSVARCHAR50校区3XNVARCHAR4学年4XQVARCHAR4学期5XYBHVARCHAR10学院编号6ZYBHVARCHAR200专业编号7KCMCVARCHAR60课程名称8BJVARCHAR200班级9BOOKINFOIDINT4教材信息表ID10NUMINT4订购数量(3)教材订单表B_BOOKORDER是教材订单表,用于记录学年、学期、订单编号、订单名称等基本信息,以ID作为主键。其字段如表43所示。表43教材订单表(B_BOOKORDER)序号列名数据类型长度说明1IDINT4表ID2XNVARCHAR4学年3XQVARCHAR4学期4ORDERNOVARCHAR16订单编号5ORDERNAMEVARCHAR50订单名称6ORDERDATEDATETIME8订单日期7ORDEROPERATORVARCHAR12操作人8ORDERCHECKINT40未审核1审核(4)订单书籍详细表B_BOOKORDERLIST是订单书籍详细表,用于记录订单ID、教材基本信息ID、订购数量等基本信息,以ID作为主键,ORDERID关联订单表,BOOKINFOID关联教材基本信息表。其字段如表44所示。表44订单书籍详细列表(B_BOOKORDERLIST)序号列名数据类型长度说明1IDINT4表ID2ORDERIDINT4订单表ID3BOOKINFOIDINT4教材基本信息ID4ORDERNUMINT4订购数量(5)教材入库表B_BOOKSTORAGE是教材入库表,用于记录教材基本信息ID、入库数量、采购价、出库价等基本信息,以ID作为主键,BOOKINFOID关联教材基本信息表。其字段如表45所示。表45教材入库表(B_BOOKSTORAGE)序号列名数据类型长度说明1IDINT4表ID2BOOKINFOIDINT4教材基本信息ID3INNUMINT4入库数量4INDATEDATETIME8入库日期5INOPERATORVARCHAR12操作人6BOOKSELLERVARCHAR50书商7NOTESVARCHAR200备注8TOTALAMOUNTDECIMAL9总金额9PURCHASEPRICEDECIMAL9采购价10OUTPRICEDECIMAL9出库价(6)班级退书表B_CLASSEXITBOOK是班级退书表,用于记录学年、学期、班级、退书数量等基本信息,以ID作为主键,BOOKINFOID关联教材基本信息表。其字段如表46所示。表46班级退书表(B_CLASSEXITBOOK)序号列名数据类型长度说明1IDINT4表ID2XNVARCHAR4学年3XQVARCHAR4学期4BHVARCHAR8班级5BOOKINFOIDINT4教材基本信息ID6RBKNUMINT4退书数量7RBKPERSONVARCHAR12退书人8BOPERATORVARCHAR12操作人9BDATEDATETIME8退书日期10REASONVARCHAR200退书原因(7)班级领书出库表B_BOOKOUT是班级领书出库表,用于记录学年、学期、班级、出库数量等基本信息,以ID作为主键,BOOKINFOID关联教材基本信息表ID。其字段如表47所示。表47班级领书出库表(B_BOOKOUT)序号列名数据类型长度说明1IDINT4表ID2BHVARCHAR8班级3XNVARCHAR4学年4XQVARCHAR4学期5BOOKINFOIDINT4教材基本信息ID6OUTNUMINT4出库数量7GETBOOKPERSONVARCHAR12领书人8OUTOPERATORVARCHAR12操作人9OUTDATEDATETIME8出库日期(8)教师领书出库表B_TEACHERGETBOOK是教材领书出库表,用于记录学年、学期、教师姓名、领书数量等基本信息,以ID作为主键,BOOKINFOID关联教材基本信息表ID。其字段如表48所示。表48教师领书出库表(B_TEACHERGETBOOK)序号列名数据类型长度说明1IDINT4表ID2XNVARCHAR4学年3XQVARCHAR4学期4XYBHVARCHAR10学院编号5TEACHERNAMEVARCHAR12教师姓名6BOOKINFOIDINT4教材基本信息ID7GETBOOKNUMINT4领书数量8GETBOOKDATEDATETIME8领书日期9HANDLEPERSONVARCHAR12操作人(9)书库退书表B_REFUNDBOOK是书库退书表,用于记录教材基本信息ID、退书数量、原因、日期等基本信息,以ID作为主键,BOOKINFOID关联教材基本信息表ID。其字段如表49所示。表49书库退书表(B_REFUNDBOOK)序号列名数据类型长度说明1IDINT4表ID2BOOKINFOIDINT4教材基本信息ID3OUTNUMINT4退书数量4PRESSVARCHAR50书商5REFUNDBOOKDATEVARCHAR50退书日期6REASONVARCHAR200原因7ROPERATORVARCHAR12操作人(10)系统用户表B_MANAGER是系统用户表,用于记录用户名、密码、部门编号等基本信息,以ID作为主键。其字段如表410所示。表410用户表(B_MANAGER)序号列名数据类型长度说明1MANAGERIDINT4用户ID2USERNAMEVARCHAR20用户名3REALNAMEVARCHAR10真实姓名4PASSWORDVARCHAR20密码5DWBHVARCHAR20部门编号6TELEPHONENUMBERVARCHAR20固定电话7EMAILVARCHAR30电子邮件8MOBILENUMBERVARCHAR11移动电话9IPCHECKVARCHAR20IP地址443重要数据库表之间的关系如图45所示。图45重要数据库表之间的关系本章概述本章对系统的员工管理、工作记录管理、工资支取管理、工资结算以及报表打印的实现进行了详细的描述,包括实现效果图和部分核心代码。45能的实现本系统采用MVC模式,该模式是基于STRUTS框架实现的,由于STRUTS已经为我们提供了一个非常好的MVC框架,我们利用STRUTS开发MVC系统时可以大大加快开发的速度。在前面的第2章中已经介绍过STRUTS原理,现只针对档案管理模块研究STRUTS框架。该模块可以查看员工的详细信息、可以添加员工档案(包括基本信息、学习经历、工作简历、获证情况、家庭成员、岗位信息)、可以按不同的选择条件分页查看单个或多个员工档案信息、可以对员工进行考核,奖惩,福利发放,异动,离职退休,培训操作、还可以打印员工的档案信息。登陆管理后台的登陆包括两种方式(员工登陆与管理员登陆)通过不同的方式登陆对系统作权限不一样,管理员登陆可根据各自不同的权限对系统的不同功能模块进行具体的操而员工登陆只能查看自己的档案信息(包括奖惩、考核、调动等)、查看工资及一些系统的提醒信息。登陆界面如图46所示图46面主界面系统后台主界面运行如图47主要是管理员的操作界面,包含人事管理、资管理、用户管理和系统管理,包括对本月或者本日员工生日到期、合同到期、离职/退休到期的做一个统计离职/退休到期的做一个统计并显示到后台首页上,以便及时做出应急措施。47台主界面员工培训管理可以查看员工的培训信息、查看培训项目的信息、可删除项目信息及自定义添加员工的培训信息、可自定义添加项目的培训信息、根据不同的条件搜索单个或多个员工的培训信息、根据不同的条件搜索项目培训信息。具体实现如图48所示图48理界面员工招聘管理可从外网接收到应聘信息、通过审核之后可选择将信息自动导入到员工档案。可对招聘信息和应聘信息进行分页查看、可自定义添加招聘信息并把招聘信息发布到前台首页、可按不同的选择条件搜索员工招聘信息及应聘信息、可查看员工的详细应聘信息。外网招聘实现如图49图49聘管理界面工资查询教师可以查询每月工资情况,若有其它项目,在查询项目里会列出,员工可以查询每一年每一月的基本工资、课时费标准、课时数、哪个校区、课时费、考绩、合计、以及所得税和实发金额等,见图5151工资查询界总结近几年来随着我校的扩招,办学规模不断扩大的前提下,原有的教材管理系统已不再满足需求,。因此,本人结合本校教材管理工作的实际情况开发了此系统。本系统采用BS的框架结构,以NET为开发平台,以C作为开发语言,以SQLSERVER作为后台数据库,运用面向对象的设计思想和UML建模知识,按照从需求分析、系统体系结构设计、数据库设计、实现的开发流程完成了教材管理系统的开发和论文的撰写。本系统完成了系统初始化、教材计划管理、订单管理、入库管理、出库

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论