考勤管理系统计算机专业毕业论文

上传人:1888****888 文档编号:38996211 上传时间:2021-11-09 格式:DOC 页数:35 大小:422.02KB
返回 下载 相关 举报
考勤管理系统计算机专业毕业论文_第1页
第1页 / 共35页
考勤管理系统计算机专业毕业论文_第2页
第2页 / 共35页
考勤管理系统计算机专业毕业论文_第3页
第3页 / 共35页
点击查看更多>>
资源描述
I考勤管理系统考勤管理系统【摘要】考勤管理系统能够帮助公司单位在人事管理上对员工信息进行管理,系统全面实现了公司的基本管理要求,能大大提高公司的工作效率和管理能力。本课题就是为了适应信息化时代潮流而提出的。它的使用结合 机读磁卡进行公司的日常考勤,可以实现日常考勤、考勤统计、考勤的查询、员工管理等一系列工作的智能化、数字化,从而代替昔日费时、费力易错、枯燥乏味的人工考勤方式。使公司能够对员工的各种信息进行全面统计,方便公司做出恰当的奖惩制度。本系统我主要设计了登录模块,主模块,考勤管理模块。系统使用 delphi7.0 软件开发工具,SQL Server 数据库。【关键词】考勤 考勤统计 考勤查询 模块【Abstract】This manage system check on work attendance helps the company to manage staff in several aspects. The system can provided a comprehensive function,can greatly improve the capacity of the management and the work efficiency.This program was made to adapt the era tideway,this system work with the timecard can improve efficiency of the company,it can actualize the daily check on work attendance,the attendanceStat,the attendancequery, the employee management and so on.This program can replace the old check on work attendance which is timewaste and hard sledding,with it the company can make right decisions.In the whole system, I contrive the login module,main module,and the attendance module.Our system made out of Delphi7.0 and SQL Server databaseKeyword:Check on work attendance Attendance-StatAttendance-Query Module II目 录第第 1 1 章章 绪绪 论论.1 11.1 课题应用背景.11.2 现有产品和存在问题.11.3 本选题可行性及现实意义.21.4 课题的制作.3第第 2 2 章章 需求分析需求分析.4 42.1 功能需求分析.42.2 软硬件分析.52.3 运行环境要求.5第第 3 3 章章 概要设计与详细设计概要设计与详细设计.6 63.1 系统设计原则.63.2 系统功能设计.63.2.1 系统的功能模块图 .73.2.2 系统的数据流程图 .73.2.3 主要的数据字典 .93.2.4 系统的主程序流程图 .103.3 各个子模块的功能设计.103.3.1 用户登录模块 .103.3.2 考勤信息管理模块 .103.3.3 数据库管理模块 .113.4 硬件单元.11第第 4 4 章章 开发方法及开发工具简介开发方法及开发工具简介.14144.1 开发方法.144.2 开发工具.15 III第第 5 5 章章 数据库设计数据库设计.16165.1 数据库设计遵循的一般原则.165.2 数据库需求分析.165.3 数据库概念结构设计.175.4 各数据表的设计.185.5 数据库安全.21第第 6 6 章章 实现实现.22226.1 用户登陆子模块.226.2 主功能模块.236.3 时间设置模块.246.4 考勤管理模块.25第第 7 7 章章 测试与调试测试与调试.28287.1 测试.287.2 调试.28第第 8 8 章章 结束语结束语.32328.1 研究成果.328.2 总结与展望.32致致 谢谢.3434参考文献参考文献.3535 1第第 1 1 章章 绪绪 论论1.1 课题应用背景课题应用背景随着信息化的发展,各公司规模的不断扩大,员工管理越来越复杂,考勤的时间又很短,且工作量大, 而考勤管理在公司、企业中起着举足轻重的作用。因为人员考勤管理涉及到工资、福利等与员工个人利益相关的事物,一个经济实体考勤管理工作的好坏,直接影响到员工主观能动性的发挥,从而影响到企业的经济利益。伴随着经济实体的发展壮大公司员工的数量也越来越多。显然,传统的考勤制度。如手工考勤已越来越不适应时代的发展,使用计算机进行人员考勤管理已经成为一种迫切的需要。经过我们的详细的调查,目前,许多单位员工考勤还停留在人工管理的基础上,这样的管理方法浪费许多人力和物力,随着科学技术的不断提高这种传统的手工管理方法必然被以计算机为基础的信息管理方法所取代.使用计算机进行管理不仅可以降低管理工作的难度,也可以减少错误和提高效率.因此,开发一套能够为公司提供充足的信息和快捷的查询手段的考勤管理,是非常必要的.本设计是从西安华龙公司的实际考勤业务需求出发,针对该公司人工考勤管理的现状,经过详细的系统调查,为该公司设计同时又有较强的通用性的前提下开发出的一个使用的智能卡考勤系统管理系统。1.2 现有产品和存在问题现有产品和存在问题目前市场上,考勤系统已经有很多产品的存在,据我们调研分析,当前的考勤状况非常混乱,高低不齐。有的大公司,有着良好的智能化考勤系统;而有的中小公司的考勤系统不是智能化不强,就是有设备不用,随意性较强。小公司则更加混乱。目前市场上所使用的考勤管理系统有以下三类:1、人工管理系统完全的人工管理,员工每次上班都以签名的方式进行登记,这种管理系统是最原始的管理方法,基本上已被社会所淘汰,但一些小单位仍在使用。2、指纹考勤管理系统指纹考勤管理系统,在一些安全性要求较高的地方有较多应用。在员工考勤系 2统中,这是较为新型的产品。指纹考勤管理系统是利用人的指纹作为身份唯一识别。硬件是一智能考勤机作为前台,电脑作为后台信息处理,先对员工指纹进行采样库存。考勤时对员工指纹与指纹库进行比较。当确认以后,记录员工的出勤时间、日期、后台管理系统进行核对操作。指纹考勤系统的缺点:利用指纹考勤,理论上是可行的,杜绝了代打卡现象。但实际应用中,有一些人员指纹无法识别,并且会出现“误判”现象,此外对光线、温度、湿度的要求也比较严格,适应性差。3、纸卡考勤系统纸卡考勤系统是半机械化半人工的考勤系统。其特点是价格底,但要求人进行统计和核算。纸卡机的工作原理是利用一个纸卡机,员工用属于自己的纸卡在“统计卡”上打上时间,记录上下班时间。统计卡是消耗品,目前此系统存在的问题是:代打卡现象极为严重,且需专人看管。但投入成本底。纸卡机属于较早的一代考勤系统,十分浪费人力,并没有在真正意义上实现信息化,是面临淘汰的产品,但目前仍被使用。4、智能磁卡考勤系统智能磁卡考勤系统是一个磁卡机和电脑相连,这是真正信息化的考勤系统。有着良好的管理功能,直接对信息进行管理,如统计、打印、修改等。它的工作原理是:利用员工每个人都有一个电脑能够唯一识别的字串,代表个人的唯一编码。电脑以此作为对员工工作的唯一识别和记录处理。虽然,磁卡机考勤系统有着极方便的管理能力。但代打卡现象仍然很严重。智能磁卡是真正意义上的数字化考勤,但仍需改进其不足之处。 ,智能磁卡考勤系统,较适应大中型企业,有较大的处理和管理功能。1.3 本选题可行性及现实意义本选题可行性及现实意义通过调研,目前市场上的其它各种考勤系统与智能卡考勤系统相比,无一例外地存在不足。市场上的纸卡机考勤系统仍在使用但面临淘汰;指纹考勤系统技术和硬件设备还有待提高。智能磁卡考勤系统是最主流的考勤设备。所以说,智能磁卡考勤系统是具有成熟的市场和技术的!就开发时间短、开发风险小、开发成本底、适用性强等特点,这都是纸卡、指纹考勤系统所不能比拟的,研究和设计它还是有很强的实用性的。 智能磁卡考勤系统采用 Delphi 数据库开发技术和射频磁卡技术开发。与其他考 3勤系统相比具有以下几个优点:1、适应性范围广。智能磁卡考勤系统不受温度、光线等环境条件的限制;另外,采用 Delphi 数据库开发技术,支持网络传输,不受距离限制。2、管理功能强大。用 Delphi 开发的考勤管理系统具有强大的数据库管理功能和可维护性。大大的降低了工作员的工作量和操作难度。3、成本低。由于软件易于操作,大大降低了软件开发成本和维护费用。硬件采用较为成熟的射频卡技术:磁卡机为 500-800 元,每张磁卡为 6-8 元。本课题组以 “智能卡智能考勤系统设计”为题,在指导老师的指导下,初步开发相关的应用程序,解决传统考勤的不足。这对于我们深入理解所学知识,提高综合应用能力,无疑具有很大的现实意义。1.4 课题的制作课题的制作智能考勤系统的软件开发有我和李晓红共同开发完成,在软件开发中我主要做登录模块,主模块,考勤管理模块的设计和开发工作。 4第第 2 2 章章 需求分析需求分析需求分析是进行系统开发的基础。通过需求分析,可以明确用户需求,确定系统功能。具体而言,我们从如下几个方面进行了分析:2.1 功能需求分析功能需求分析功能需求主要是为了明确所开发的软件必须具备的功能。考勤是相对繁琐的工作,公司每天都要对员工进行考勤,员工上班时在考勤系统上登陆,下班时进行注销,系统会自动记录,这样可以节省许多时间。当员工不能正常上班时,如出差、请假等,可以给系统操作员说明原因,然后在考勤系统上进行记录,在每个月进行结算工资是根据考勤系统的记录来增减个人薪金。考勤信息的来源,可以直接由考勤人员手工输入,也可以由每个员工登陆考勤系统,进行注册。当然还有其他方式进行考勤信息输入。在本文所阐述的系统中,所有员工都通过智能卡识别来进行登陆和注销,同时系统需要密码才能进入。每个员工的智能卡信息已通过采集,转化为数据信息,每次智能卡识别将激活系统的考勤资料输入模块。这个模块也可以用手工输入,以备例外情况。根据分析,在本系统中,我们需要实现以下一些基本功能:(1)员工管理:可以添加、删除、查询、修改员工的基本资料。(2)帐户管理:系统管理员可以添加、删除、查询系统操作员,并指定各操作人员的权限(权限管理) 。(3)考勤管理:系统操作员可以设置上下班时间,并能对出差、加班、请假信息进行添加,修改和删除。(4) 。考勤统计管理:操作员可以对员工的考勤资料进行统计,并可产生报表;员工也可以登陆系统查询个人考勤资料。(5)数据库备份:对现有的数据库进行管理,包括数据库压缩、备份和恢复,以方便用户对数据库的管理和维护工作(6)数据查询:可以对员工信息进行查询,也可以对统计信息进行按条件查询。包括迟到、早退、缺勤、信息,出差信息,加班信息和请假信息的查询。(7)打印输出:可以对统计信息,查询信息产生报表并进行打印输出 52.2 软硬件分析软硬件分析智能磁卡考勤系统采用 Delphi 数据库开发技术和射频磁卡技术开发。与其他考勤系统相比具有以下几个优点:1、适应性范围广。智能磁卡考勤系统不受温度、光线等环境条件的限制;另外,采用 Delphi 数据库开发技术,支持网络传输,不受距离限制。2、管理功能强大。基于 Delphi 的考勤管理系统具有强大的数据库管理功能和可维护性。大大的降低了工作员的工作量和操作难度。3、成本低。由于软件易于操作,大大降低了软件开发成本和维护费用。硬件采用较为成熟的射频卡技术:磁卡机为 500-800 元,每张磁卡为 6-8 元。硬件成本较低,且采用非接触式射频技术,硬件属于非易耗品。 2.3 运行环境要求运行环境要求系统的运行对运行环境还有一些要求:1、硬件环境:处理器:Intel Pentium 166MX 或更高;内存:至少 64MB 建议 128MB 或更多;硬盘:1GB;显卡:SVGA 显示适配器;2、软件环境:操作系统:Windows98/2000/Me/XP数 据 库:Microsoft SQL Server软件开发工具:Delphi7.0 6第第 3 3 章章 概要设计与详细设计概要设计与详细设计3.1 系统设计原则系统设计原则在当前诸多条件制约下,首先要研究智能考勤系统的实用性,使用户真正得到效益,充分发挥它的作用。同时又要注重它的科学性,以促进管理的现代化。智能考勤系统开发的原则如下:1、可行性原则。系统要保证技术上的可靠性和经济上的可行性。计算机系统、通讯网络系统设计和数据设计,在技术上必须是成熟的,经实践检验是成功的,在经济上是可能实现的。2、适应性原则。系统要保证可扩展性、可维护性。系统软、硬件都要有扩充升级的充分余地,系统要便于维护,系统对用户的需求要有一定的适应能力。3、安全性及保密性原则。智能考勤系统是实现薪金结算的基础,如果哪一个环节出现问题,例如系统操作员数据泄密,可能会导致财务结算系统混乱,后果不堪设想。因此,必须设置用户权限,以保证系统有较好的安全性,同时,系统也应有较强的数据备份和数据恢复功能。4、人机结合原则。人工信息收集系统与计算机管理信息系统要紧密结合。完整、准确、及时的信息是信息系统运行的基础。计算机系统是提供信息处理及辅助决策的技术手段,人工系统与计算机系统要有机的结合,友好的人-机界面是系统设计的主要原则之一。5、系统工程原则。系统调查、系统分析、系统设计、软件开发以及实施都要遵照系统工程的方法和步骤一步一步地进行,以便确保系统的整体性。6、统一规划、分期实施、逐步完善原则。管理信息系统要按规划、分阶段实施,由点到面逐步扩充,逐步完善,循序渐进。3.2 系统功能设计系统功能设计系统设计是根据需求分析的结果,设计系统的模块和结果之间的内在联系。 73.2.1 系统的功能模块图系统的功能模块图智能考勤管理系统管理员身份验证考勤管理帐户管理考勤管理数据备份数据查询考勤统计打印输出员工管理修改密码添加用户删除用户图 3-1系统的功能模块图3.2.2 系统的数据流程图系统的数据流程图出勤的原始时间记录主要来源于智能卡考勤机,并且以固定格式保存在数据库中。系统的各部分数据流程图如下所示.1)出勤管理数据流程图如下所示: 出勤信息管理员信息系统管理员11系统登陆D1出勤信息12系统管 理D3员工信息D2图 3-2 出勤管理数据流程图 8(2)添加加班记录数据流图如下所示:员工信息系统管理员21系统登陆D2D4加班信息加班信息22加班管理图 3-3 添加加班记录数据流图(3)添加请假记录录数据流图如下所示:员工请假信息系统管理员出勤信息请假信息经理请假信息31请假批示D532系统管 理D631记录登记图 3-4 添加请假记录数据流图 93.2.3 主要的数据字典主要的数据字典名字:员工编号描述:唯一的标识员工的关键域定义:员工编号6字符6位置:考勤信息出差信息请假信息加班信息统计报表图 3-5 员工编号的数据字典 图 3-6 加班表的数据字典名字:考勤表描述:每天记录员工出勤状态的表定义:考勤表员工编号日期刷卡时间出入状态位置:统计时,将其内容计入统计表并判断员工状态名字:请假表描述:记录员工请假信息的表定义:请假表员工编号开始时间结束时间描述位置:由统计表对其进行统计图 3-7 考勤表的数据字典 图 3-8 请假表的数据字典名字:加班表描述:每天记录员工出勤状态的表定义:加班表员工编号日期加班时间位置:统计时,将其内容计入统计表并判断员工状态 103.2.4 系统的主程序流程图系统的主程序流程图图 3-9 系统主程序流程图3.3 各个子模块的功能设计各个子模块的功能设计3.3.1 用户登录模块用户登录模块功能:由用户输入用户名和密码。如果用户名和相应密码正确,则根据该用户的权限类别进行权限设置;若用户名和密码错误,则进行错误提示,且只允许用户输入 3 次,超过 3 次系统自动退出。系统管理员进入考勤操作主界面。一般管理员进入一般管理员界面,相应的操作会受到限制。例如:不能添加,删除管理员,不能修改用户权限。3.3.2 考勤信息管理模块考勤信息管理模块功能:本模块主要实现对上、下班时间设置,同时对出勤信息,加班信息,请假信息,出差信息进行添加、删除、修改等操作。功能结构图如图 3-10 所示: 11考勤管理上下班时间设置出勤管理请假管理加班管理出差管理添加更改修改删除图 3-10 考勤信息管理模块功能结构图相关数据表: 考勤表,请假表,出差表,加班表。3.3.3 数据库管理模块数据库管理模块功能:本模块实现对系统数据库的备份和还原,以防止出现数据丢失等致命错误。功能结构图 如图 3-11 所示:图 3-11 数据库管理模块功能结构图3.4 硬件单元硬件单元系统的硬件有射频卡、读卡机、计算机组成。射频卡读/写单元是一个比较常用的自动控制设备部件这是一种非接触式读/写程序。射频卡读写单元的结构框图如下: 12图 3-12 射频卡读写单元的结构框图射频卡读/写单元产品采用串口通信技术。射频卡读写单元提供与微控制器通信的 TTL 通信接口。数据传输采用标准串行方式。主板模块采用四芯排线与外界相连。排线定义方式如下:(芯片端口向上,面对接口插座)从左到右依次为Vcc,GND,TXD,RXD。1、射频卡读、射频卡读/写单元特性写单元特性(1)具有精简的指令集,可将射频卡基本操作集成几条命令,操作简便。(2)具有读、写、增、减、初始化射频卡装载密码等功能。(3)对射频工作的频率为 13.56MHz。(4)对射频卡的操作距离为 25mm。(5)数据传输速率 115200bit/s,通信错误侦测。(6)TTL 通信接口。(7)单电源供电:+5V。2、射频卡读、射频卡读/写命令集写命令集(1)LOADKEY:改变存放于 RF 读写单元内部的授权密码。(2)READ:读出卡片中模块的数据。(3)WRITE:将数据写入卡片中的模块。 13(4)INITVAL:将卡片中某扇区的内容赋予初值,并初始化为可供增减的模块。(5)DECREMENT:将卡片中某扇区的内容减去某一数值。(6)INCREMENT:将卡片中某扇区的内容加上某一数值。3、射频卡读、射频卡读/写单元编程协议写单元编程协议协议规定:该通信数据传输速率 115200BIT/S。通信格式为一位起始位,八位数据位。一位结束位,无奇偶校验位,数据最大长度为 32 字节。开始通信时,接收机和发送机都处于就绪状态。首先,发送机发送一个起始信号(STX) ,正常返回一个 DLE 信号,之后开始通信,反之,若无应答,重复三次。三次之后仍无应答则停止,不再通信。当数据块中的数据为 10H 时将被发送两次。通信数据之间的最大时间间隔为0.5S,如果时间间隔大于 0.5S 就认为通信失败。 14第第 4 4 章章 开发方法及开发工具简介开发方法及开发工具简介4.1 开发方法开发方法目前流行的系统开发方法主要有生命周期法、快速原型法、面向对象开发方法等,每种方法各有特色。生命周期法是一种有效、成熟的方法,它对软件生产实现工程化起了重要作用,但是应用该方法的前提条件是必须确定系统的需求,才能得到预期的正确结果。对于信息系统来讲,由于其问题空间十分庞大,不论开发者在系统分析时采用何种严格的方法力争准确地描述用户需求,在系统没有开发到一定程度,用户对系统的理解达不到一定的程度是无法准确表达出需求的。这并不是说用户需求捉摸不定。为了解决需求的模糊性和变化性,出现了另一类系统开发方法,即快速原型法。快速原型法是在系统分析基础上,由开发者尽快构造出一个应用系统原型,经用户初步应用,对系统有了一定的认识后,再由系统开发者与用户反复进行交流,逐步完善达到最终目标。快速原型法不仅是一种方法,更是一种技巧,它可以运用与系统开发的各个阶段,例如在系统分析阶段用于提炼用户需求,在系统实现阶段开发软件原型等。面向对象的开发方法着眼于所研究的问题,对问题空间进行自然分割,识别其中的对象及其相互联系,建立问题空间的信息模型。其基本思想是把信息系统本身看成是一系列离散的对象的集合。这些对象即包括数据结构,也包括在这些数据结构上的操作与行为。各对象之间由事件触发,引发互通消息而实现互操作。这样设计出的软件必然是模块化的、可重用的、可扩充的和可移植的,克服了过去由于分析设计与实施割裂所造成的程序编制必须到设计后期才能进行的程序沉淀现象。面向对象方法的主要优点并不是减少开发时间,它可能比传统的结构化方法的开发时间还要长一些。它的主要目标是促进未来系统的可重用性,减少后续阶段的开发量,从而大大提高软件生产率与可维护性。综观上述各种方法,考虑到信息系统开发过程的顺序性和开发过程的固有特点,结合实际开发的经验教训,我们认为各种不同的系统开发方法适用于各自不同的领域。本设计主要采用面向对象的开发方法。4.2 开发工具开发工具“智能考勤系统”设计为 Client/Server 结构的应用程序。客户端采用 Delphi7.0 15作为前端开发工具,采用ADO 设置数据源,后台采用 Microsoft SQL Server 2000数据库。系统运行的操作系统为 Windows98/NT/Me/2000/XP。下面简要介绍各个开发工具。Delphi 被称为第四代程序开发语言,是一种常用的可视化编程工具,集成了大量的可视化控件,程序员只需要做少量的工作就能完成大量复杂的工作。同时,Delphi 还具有功能强大,运行高效,界面简洁等特点。它与 Visual C+相比,在功能上豪不逊色,而且更容易掌握;与 Visual Basic 相比,Delphi 具有更强大的功能。可以说 Delphi 集合了 Visual C+强大的功能和 Visual Basic 的操作简便。因此,利用 Delphi 编写 Windows 开发应用程序十分方便。Delphi7.0 是公司在 2002 年 8 月推出的新版本。与以往的各个版本相比,不仅继承了功能强大、成熟而丰富的组件,同时又增加了一些新的特性,如企业应用的MDA 开发,可视化的快速 Web 开发,免费的 Datasnap 多层应用开发以及基于Windows XP 的应用。Microsoft SQL Server 2000 是 Microsoft 在 SQL Server 7.0 基础上推出的新一代大型电子商务、数据转换服务、数据仓库服务等方面引入了大量新的特性,为 Web标准提供了大量支持,并为系统管理提供了许多有力的工具。 16第第 5 5 章章 数据库设计数据库设计5.1 数据库设计遵循的一般原则数据库设计遵循的一般原则数据库设计是构建一个系统的关键。这是因为数据库设计的优劣将直接影响系统数据的安全性、可靠性。在数据库的设计过程中,需要遵循的一般原则是:(1) 、数据库各表的设计要反映现实中的事物。数据表中的字段类型和大小要符合使用习惯。(2) 、减少数据库的冗余和数据的不一致性。数据库应用的一个特点是对数据库的频繁操作,每次操作可能只会涉及一个表,也可以同时涉及多个表,也有可能对一个数据表进行多个操作,在这种情况下,由于数据冗余和数据不一致时,可能会引起错误。(3) 、要有助于提高数据处理速度。程序访问数据库的速度依赖于硬件的速度,数据量的大小和数据表设计的优劣,而前两个因素是很难更改的。(4) 、要保证数据库的安全。安全性是数据库应用软件的重要要求。5.2 数据库需求分析数据库需求分析根据数据流程图(图 3-2,3-3,3-4) ,可以列出以下管理系统所需的数据项和数据结构。1、出勤记录:记录号、员工、出入情况、出入时间。2、请假记录:记录号、员工、假期起始时间、假期结束时间、请假原由。3、加班记录:记录号、员工、加班时间长度、日期。4、出差记录:记录号、员工、出差起始时间、出差结束时间、具体描述。 5、月度考勤统计:记录号、员工、年月、累计正常工作时间、累计请假时间、累计加班时间、累计出差时间、迟到次数、早退次数、矿工次数。6、所需的外部数据支持:(1) 、员工信息:员工号、密码、权限、姓名、部 门、当前状态等。(2)部门信息:部门编号、名称等。5.3 数据库概念结构设计数据库概念结构设计出勤管理系统的 E-R 图: 17密码员工编号所属部门图 5-1 出勤管理系统的 E-R 图请假管理,出差管理,加班管理的概念结构设计基本相同,现举例请假管理的 E-R 图如下页:员工姓名MNN图 5-2 请假管理系统的 E-R 图MNN1员工员工姓名员工地址密码记录系统管理员用户权限用户名操作出勤信息员工编号出入状态具体时间系统管理员用户权限用户名密码操作1员工员工编号员工地址所属部门密码记录请假信息员工编号请假开始时间状态请假结束时间请假缘由 185.4 各数据表的设计各数据表的设计数据库设计是构建一个系统的关键,根据系统各模块的功能和它们要处理的数据,可以基本确定数据库中各表的字段结构。本系统采用 SQL Server 2000 建立数据库。数据库中表结构设计如下:表 5-1:ATTENDANCE 出勤记录表字段名数据类型是否可空说明ID INTEGRENOTNULL记录编号(主关键字)PERSONCHAR(6)NOTNULL员工号(外部关键字)IN_OUTCHAR(1)NOTNULL出入情况IO_TIMEDATENOTNULL出入时间表 5-2: LEAVE 请假记录表字段名数据类型是否可空说明IDINTEGERNOTNULL记录编号PERSONCHAR(6)NOTNULL员工号START-TIMEDATENOTNULL假期开始时间END-TIME DATENOTNULL假期结束时间REASONVARCHAR(10)NOTNULL请假原由 19表 5-3:LOGIN 管理员用户表字段名数据类型是否可空说明USERNAMECHAR(10)NOT NULL用户名PASSWDCHAR(10)NOT NULL密码AUTHORITYCHAR(10)YES用户权限表 5-4 : OVERTIME 加班时间字段名数据类型是否可空说明IDINTEGERNOT NULL记录编号PERSONCHAR(6)NOT NULL员工号WORE-HOURSSMALLINTNOT NULL加班时间WORE-DATEDATENOT NULL加班日期 表 5-5: ERRAND 出差记录表字段名数据类型是否可空说明IDINTGERNOTNULL记录编号PERSONCHAR(6)NOT NULL员工号START-TIMEDATENOT NULL出差开始时间END-TIMEDATENOT NULL出差结束时间DESCRIPTIONVARCHAR(6)NOT NULL具体描述 表 5-6:PERSON 员工个人信息表字段名数据类型是否可空说明IDCHAR(6)NOTNULL员工号(主关键字)PASSWDCHAR(20)NOTNULL密码AUTHORITYCHAR(1)YES用户权限NAMEVARCHAR(10)YES姓名SEXCHAR(1)NOTNULL性别BIRTHDAYDATEYES生日DEPARTEMENTCHAR(3)YES所在部门JOBCHAR(3)YES职务EDULEVELCHAR(1)YES受教育程度SPECIALTYVARCHAR(20)YES专业技能ADDRESSVARCHAR(50)YES家庭住址TELVARCHAR(20)YES联系电话 20EMAILVARCHAR(50)YES电子邮箱STATECHAR(1)YES当前状态(T,F)REMARKVARCHA(400)YES备注 21表 5-7: DERARTMENT 部门信息表字段名数据类型是否可空说明IDCHAR(3)NOTNULL部门编号NAMEVARCHAR(20)NOT NULL部门名称MANAGERCHAR(6)YES部门经理INTROVARCHAR(4000)YES备注表 5-8:COUNTER 计数器表字段名数据类型是否可空说明IDCHAR(1)NOT NULL计数器编号COUNTER-VALUEINTEGERNOT NULL记数值DESCRIPTIONVARCHAR(10)YES描述5.5 数据库安全数据库安全用 DELPHI 的 DBNAVIGATOR、TABLE、DATASET 组件来实现多客户的程序时,向主表插入一条新记录,编辑好后直接提交,往往会出现线路被占用不能提交数据错误。在数据库中有一个特定的名词“脏数据” ,用来描述那些被某事物变更但是还没有提交的数据。那么如何解决用户同时访问数据的问题呢?总不能因为并发而限制用户的操作吧!并发控制的解决方案是“锁(LOCKING) ”和事物。从数据库的角度来看,锁有两种类型:排它锁(EXCLUSIVE LOCKS,简称 X锁)和共享锁(SHARE LOCKS,简称 S 锁) 。X 锁只允许加锁的事物进行操作,其他事物禁止加锁和任何操作。其他事物必须等待解锁才能继续运行!S 锁可以允许多个事物同时对数据加锁,如果事物 T 对数据 R 加了 S 锁,那么其他的事物就不能再对 R 加 X 锁这样可以保证其他事物不能修改 R。另外,还有一个加锁的范围需要考虑,我们可以进行行加锁,也可以进行表加锁,甚至还可以进行数据库加锁。加锁的范围越大,那么实现就越简单,开销就越小,数据的并发程序就越底!反之,如果加锁范围越小,那么实现就越复杂,开销就越大,数据的并发程序就越高!一般的,考虑到加锁成本和性能,处理少量数据的事物应该尽可能减少加锁的作用范围,提高数据的并发程度,应该采用行锁,防止则应该采用表锁等。另外,当一个事物操作完毕的时候,应尽可能快的解锁。 22第第 6 6 章章 实现实现6.1 用户登陆子模块用户登陆子模块设置登陆界面是保障系统安全的一种手段,一般的数据库应用系统都需要进行登陆才能进入系统。在这个模块里,主要处理用户输入的用户名和用户密码,程序根据用户名和用户密码进行权限判断,并进入不同的操作界面。用户登录模块的程序流程图如图 6-1 所示:用户登录界面如图 6-2 所示:图 6-1 用户登陆模块程序流程图 23图 6-2 用户登录界面6.2 主功能模块主功能模块系统的主功能模块界面如下图:图 6-3 系统主功能界面主功能界面的 formcreat 事件代码为:frmsplash:=tfrmsplash.create(application);frmsplash.showmodal;loginfrm:=tloginfrm.Create(application);while n=3 thenbeginmessagedlg(您已经登录失败 3 次,程序将终止,mtwarning,mbok,0);close;application.Terminate;exit;endelsemessagedlg(密码错误,请重试,mtwarning,mbok,0);end;6.3 时间设置模块时间设置模块考勤系统的时间设置界面如下:图 6-4 时间设置界面修改按钮的 click 事件代码为:varMyInifile:Tinifile;beginMyInifile:=Tinifile.Create(ExtractFilePath(Paramstr(0)+workplan.ini);MyInifile.WriteString(WorkPlan,Time1,i_time1.Text);MyInifile.WriteString(WorkPlan,Time2,i_time2.Text);MyInifile.WriteString(WorkPlan,Time3,i_time3.Text); 25MyInifile.WriteString(WorkPlan,Time4,i_time4.Text);end;6.4 考勤管理模块考勤管理模块(1)考勤管理模块的界面如下页图:图 6-5 出勤记录界面单个员工的 click 事件代码为:beginT_counter.Filter:=ID=”A”;T_counter.Filtered:=True;T_counter.Open;counter:=T_counterCOUNTER_VALUE;Inc(counter);T_counter.Edit;T_counterCOUNTER_VALUE:=counter;T_counter.Post;T_counter.Close;if i_in_out.ItemIndex=0 thenin_out:=O elsein_out:=I;io_time:=StrToDateTime(i_io_time.Text);T_attendance.Filtered:=False;T_attendance.Open;T_attendance.AppendRecord(counter,Person_id,in_out,io_time);end;(2)加班记录与请假记录和出差记录模块:加班记录与请假记录和出差记录模块界面相同如下: 26图 6-6 请假记录界面考勤修改的按条件检索的 click 事件代码为:beginClose;FilterStr:=”;if Seek_by_person.Checked thenFilterStr:=PERSON=”+Seek_person_id.Text+”;if Seek_by_time.Checked thenbeginif length(FilterStr)0 thenFilterStr:=FilterStr+ AND ;FilterStr:=FilterStr+IO_TIME+Seek_start_time.Text;FilterStr:=FilterStr+ AND IO_TIME0 thenbeginFilter:=FilterStr;Filtered:=True;endelseFiltered:=False;Open;end;end; 27第第 7 7 章章 测试与调试测试与调试7.1 测试测试白盒测试是一种以程序的内部逻辑结构为依据而设计测试用例的方法,因而又称为结构测试法或玻璃盒测试法。合理的白盒测试就是要选取足够的测试用例,对源代码实行比较充分的覆盖,以便尽可能多的发现程序中的错误。主要有两种方法:一种是逻辑覆盖法,另一种称为路径覆盖法。在这里我们采用逻辑覆盖法。在开发智能考勤系统的时候,我们对系统使用白盒测试技术进行了全面测试,采取的具体测试思路是:1. 菜单项测试:为了保证每一项下拉菜单能正确实现系统设计的功能,我把考勤系统所需的所有信息按出勤、迟到、早退、出差、请假等分类全部输入到系统中,并对每一个菜单反复进行增加、删除、修改、打印报表操作,从而保证了菜单项的正确实现。2. 数据跟踪:完成菜单项测试后,我对系统内的每一个数据进行了跟踪测试。例如:对考勤管理的“请假”这一项,我首先给其加一条请假记录:工号:L0002,姓名:刘海柱,和请假起至时间,请假原因等信息后;然后在查询模块中,分别进行“按工号查询” 、 “按时间查询”和“按时间查询”该项记录;并且在统计模块中统计“刘海柱”的请假时间、请假次数等依次验证数据流处理的正确性。3. 移植测试:我把系统拷贝到其他计算机上运行,看其移植性能和对环境的要求。综合测试:在以上测试的基础上对系统功能进行整体的测试,依此来检验系统功能是否符合设计的要求。7.2 调试调试(1)通过以下具体示例对登录模块进行调试,如图 7-1 所示: 28图 7-1 登录模块流程图满足条件覆盖的测试用例如下:覆盖方法测试路径次数=3 次?预期结果s-a-b-d-e-ffalse进入系统s-a-b-c-a-.a-b-c-a-ftrue退出系统条件覆盖s-a-.b-d-e-.a-b-d-e-ftrue退出系统 29(2)对考勤管理模块进行调试:首先是添加考勤记录:添加数据为:员工编号:L0002,则对应的员工姓名显示为:刘海柱,选者出入状态:入。点击单个员工按纽,则出勤记录自动添加一条记录为:员工编号出入状态时间L0002I2005-12-2 8:05删除记录:选中要删除的记录,点击删除当前记录,则系统自动删除此条记录,表中不再有相应的记录。检索记录:可以按照时间或员工编号进行检索。例如:选中时间,输入时间范围,点击按条件检索,则表中会显示在时间范围内的记录。选中员工,输入员工编号,点击按条件检索,则表中会显示该员工的记录。其它添加出差记录,添加请假记录,添加加班记录的测试方法与添加考勤记录的测试方法相同。按照这样的方法对逐一功能进行测试,修改错误的程序代码,最后完成整个系统的调试。 30第第 8 8 章章 结束语结束语8.1 研究成果研究成果通过实施考勤管理系统,初步实现了考勤管理的信息化。以前的公司单位需要大量的人力记录统计数据和保存 excel 文件。由于 excel 不是关系数据库结构,缺少对数据的约束,因此很容易造成数据不一致,给查询带来不便。实施考勤管理系统以来,数据实现集中存储,只需简单的操作即可完成数据的统计和查询工作。通过数据导出和打印功能,可以直接打印员工的出勤信息和其它状态信息,为公司单位对员工管理提供数据参考。系统实现了对员工出勤的记录统计管理,将统计信息备案有利于考勤管理的安全性。通过对考勤系统的管理,管理者能够实时查看员工的出勤情况,请假情况,出差情况,加班情况。及时做出决策和调整,大大提高了公司单位的工作效率,降低了管理成本。考勤管理系统作为公司管理者的平台,在实际应用中有其巨大的发展潜力。除已实现的功能外,还应该继续完善开发工作,如:如何杜绝员工代打卡现象,如何实现在线考勤等。8.2 总结与展望总结与展望通过这次毕业设计,我大致了解了在进行软件开发工作时的基本过程,并且从中获得了许多从课堂上学不到的知识和有意义的收获,其中我对以下几点有很深刻的体会:1、编程中定义窗体及变量的名称时,一定要规范,必要时加上注解,不要想当然的定义某个变量,常量等。标准的定义方式,有助于其他编程人员更容易的看懂程序代码,以便以后进行维护。2、在工作中要多与小组成员沟通与讨论,这样可以保证系统整体的一致性,而且也可以互相交流经验,从而充实和提高自己。3、编程的方法固然重要,程序的使用界面也需要注意美观,布局要合理,主题要突出,界面要友好,要让使用过计算机的用户在首次接触到该软件时,感到一目了然,只要简单翻阅一下软件使用说明书就能了解该软件的大致功能。软件界面的 31美观对软件的市场销售及以后的市场生存起着重大作用。4、在程序编好后,对程序的调试是极其重要的一步,调试程序的意义在于,可以逐步完善,改正程序中的错误,使程序尽量达到尽善尽美。在程序调试的过程中,尽量不要以编程者编程时的思想去调试,要以一个普通使用者的思维去调试。以上是我在编写程序过程中的体会,在这次毕业设计的过程中我不仅了解了软件的编写过程,更体会到软件工程的重要性。一个软件成败的关键在于需求分析和总体设计。从软件工程的角度有以下几点体会:需求分析工作是软件开发过程中重要的一步,也是决定性的一步,是要把用户“做什么”的要求转换成一个软件的逻辑模型。在实际工作中,由于用户对软件开发的不了解,往往对于软件所要达到的功能不能完全提出来,软件开发人员要完全了解用户的需求,要想到用户的前面,把用户没想到的需求也要考虑到。 在实际工作中往往不能坚持按照软件工程的原则和方法去做,致使到开发后期,步入十分被动的境地。本次毕业设计给了我一个实践的机会,锻炼了自己的意志及适应社会的能力,并且在实践中加深了对理论知识的理解,积累了编程经验,为毕业后走向社会打下了良好基础。但是由于时间的仓促和工作经验的不足及其他各个方面的原因,在软件设计中还有许多有待完善的地方:(1):系统虽然基本实现了考勤管理,但仍不能解决员工的唯一识别问题,员工仍然能存在代打卡现象。(2):SQL Server 数据库使用于规模相对数据比较多的公司,在数据库安全性上也不是很安全,应该使用安全性较高,管理更方便的数据库。 32 参考文献参考文献【1】 delphi 程序设计教程吴金华 于秋生等编著。机械工业出版设,2004年 8 月第一版【2】 delphi 编程技巧典型案例解析 电脑编程技巧与维护杂志设 编著 中国电力出版社 2005 年 7 月第一版【3】 数据库安全张敏 徐震 冯登国 编著 科学出版社 2005 年 7 月第一版【4】 Delphi.串口通信技术与工程实践赵兰涛 北京:人民邮电出版社 2004年 6 月【5】 SQL Server 数据库开发培训教程导向科技等著 北京:人民邮电出版社 2005 年 1 月【6】 软件工程(第四版) 张海藩 北京:清华大学出版社,2003 年 12 月第 4 版【7】 毕业设计指导及案例剖析 赵杰 李涛.北京:清华大学出版社,2005 年 3 月
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸下载 > CAD图纸下载


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!