计算机信息管理论文考勤管理系统_第1页
计算机信息管理论文考勤管理系统_第2页
计算机信息管理论文考勤管理系统_第3页
计算机信息管理论文考勤管理系统_第4页
计算机信息管理论文考勤管理系统_第5页
已阅读5页,还剩30页未读 继续免费阅读

下载本文档

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

文档简介

1、毕毕 业业 论论 文文 课题名称:课题名称: 考勤管理系统考勤管理系统 姓姓 名名: : 专专 业业: : 计算机信息管理 学学 号号: : 1036001407758 指导老师指导老师: : 开 题 报 告 题目:考勤管理系统考勤管理系统 报告人:计算机信息管理,张桃计算机信息管理,张桃 一、文献综述一、文献综述 随着信息化的发展,各公司规模的不断扩大,员工管理越来越复杂,考勤的时间又很短,且工作量大, 而考勤管理在公司、企业中起着举足轻重的作用。因为人员考勤管理涉及到工资、福利等与员工个人 利益相关的事物,一个经济实体考勤管理工作的好坏,直接影响到员工主观能动性的发挥,从而影响 到企业的经

2、济利益。 伴随着经济实体的发展壮大公司员工的数量也越来越多。显然,传统的考勤制度。如手工考勤已越 来越不适应时代的发展,使用计算机进行人员考勤管理已经成为一种迫切的需要。 经过我们的详细的调查,目前,许多单位员工考勤还停留在人工管理的基础上,这样的管理方法浪费 许多人力和物力,随着科学技术的不断提高这种传统的手工管理方法必然被以计算机为基础的信息管理 方法所取代. 使用计算机进行管理不仅可以降低管理工作的难度,也可以减少错误和提高效率.因此,开发一套能 够为公司提供充足的信息和快捷的查询手段的考勤管理,是非常必要的. 本设计是从深圳旭茂光电公司的实际考勤业务需求出发,针对该公司人工考勤管理的现

3、状,经过详 细的系统调查,为该公司设计同时又有较强的通用性的前提下开发出的一个使用的智能卡考勤系统管 理系统。 二、选题的目的及意义二、选题的目的及意义 通过调研,目前市场上的其它各种考勤系统与智能卡考勤系统相比,无一例外地存在不足。市场 上的纸卡机考勤系统仍在使用但面临淘汰;指纹考勤系统技术和硬件设备还有待提高。智能磁卡考勤 系统是最主流的考勤设备。所以说,智能磁卡考勤系统是具有成熟的市场和技术的!就开发时间短、 开发风险小、开发成本底、适用性强等特点,这都是纸卡、指纹考勤系统所不能比拟的,研究和设计 它还是有很强的实用性的。 智能磁卡考勤系统采用 delphi 数据库开发技术和射频磁卡技术

4、开发。与其他考勤系统相比具有以 下几个优点: 1、适应性范围广。智能磁卡考勤系统不受温度、光线等环境条件的限制;另外,采用 delphi 数 据库开发技术,支持网络传输,不受距离限制。 2、管理功能强大。用 delphi 开发的考勤管理系统具有强大的数据库管理功能和可维护性。大降 低了工作员的工作量和操作难度。 3、成本低。由于软件易于操作,大大降低了软件开发成本和维护费用。硬件采用较为成熟的射频 卡技术:磁卡机为 500-800 元,每张磁卡为 6-8 元。 三、研究的重点内容三、研究的重点内容 本毕业设计涉及到的主要内容有:本毕业设计涉及到的主要内容有: 1 1 现有产品和存在问题现有产品

5、和存在问题 2 2 课题的制作课题的制作 3 3 需求分析需求分析 4 4 功能需求分析功能需求分析 5 5 软硬件分析软硬件分析 6 6 运行环境要求运行环境要求 7 7 概要设计与详细设计概要设计与详细设计 8 8 系统设计原则系统设计原则 9 系统功能设计 本课题就是为了适应信息化时代潮流而提出的。它的使用结合 机读磁卡进行公司的日常考勤,可 以实现日常考勤、考勤统计、考勤的查询、员工管理等一系列工作的智能化、数字化,从而代替昔日 费时、费力易错、枯燥乏味的人工考勤方式。使公司能够对员工的各种信息进行全面统计,方便公司 做出恰当的奖惩制度。本系统我主要设计了登录模块,主模块,考勤管理模块

6、。系统使用 delphi7.0 软件开发工具,sql server 数据库。 四、进度安排四、进度安排 3 月 25 日4 月 25 日 分析题目,查阅资料,学习与毕业设计相关的知识,作好前期准备工作。 4 月 25 日5 月 10 日 编写论文 5 月 11 日6 月 10 日:调试软件,撰写毕业论文并征求导师意见,修改毕业论文,进行毕业论文的评议。 目目 录录 第第 1 1 章章 绪绪 论论.7 7 1.11.1 课题应用背景课题应用背景 .7 7 1.31.3 本选题可行性及现实意义本选题可行性及现实意义 .8 8 1.41.41.21.2 现有产品和存在问题现有产品和存在问题 .7 7

7、 课题的制作课题的制作 .8 8 第第 2 2 章章 需求分析需求分析 .9 9 2.12.1 功能需求分析功能需求分析 .9 9 2.22.2 软硬件分析软硬件分析 .4 4 2.32.3 运行环境要求运行环境要求 .1010 第第 3 3 章章 概要设计与详细设计概要设计与详细设计 .1111 3.13.1 系统设计原则系统设计原则 .1111 3.23.2 系统功能设计系统功能设计 .1111 3.2.1 系统的功能模块图 .12 3.2.2 系统的数据流程图 .12 3.2.3 主要的数据字典 .14 3.2.4 系统的主程序流程图 .15 3.33.3 各个子模块的功能设计各个子模块

8、的功能设计 .1515 3.3.1 用户登录模块 .15 3.3.2 考勤信息管理模块 . 3.3.3 数据库管理模块 . 3.43.4 硬件单元硬件单元 .1616 第第 4 4 章章 开发方法及开发工具简介开发方法及开发工具简介 .1919 4.14.1 开发方法开发方法 .1919 4.24.2 开发工具开发工具 . 第第 5 5 章章 数据库设计数据库设计 . 5.15.1 数据库设计遵循的一般原则数据库设计遵循的一般原则. 5.25.2 数据库需求分析数据库需求分析 . 5.35.3 数据库概念结构设计数据库概念结构设计 . 5.45.4 各数据表的设计各数据表的设计 . 5.55.

9、5 数据库安全数据库安全 . 第第 6 6 章章 实现实现 . 6.16.1 用户登陆子模块用户登陆子模块 . 6.26.2 主功能模块主功能模块 . 6.36.3 时间设置模块时间设置模块 . 6.46.4 考勤管理模块考勤管理模块 . 第第 7 7 章章 测试与调试测试与调试 . 7.17.1 测试测试 . 7.27.2 调试调试 . 第第 8 8 章章 结束语结束语 . 8.18.1 研究成果研究成果 . 8.28.2 总结与展望总结与展望 . 致致 谢谢 . 参考文献参考文献 . 摘要摘要: 考勤管理系统能够帮助公司单位在人事管理上对员工信息进行管理,系统全面实现了公司的基本管理 要求

10、,能大大提高公司的工作效率和管理能力。 本课题就是为了适应信息化时代潮流而提出的。它的使用结合 机读磁卡进行公司的日常考勤,可 以实现日常考勤、考勤统计、考勤的查询、员工管理等一系列工作的智能化、数字化,从而代替昔日 费时、费力易错、枯燥乏味的人工考勤方式。使公司能够对员工的各种信息进行全面统计,方便公司 做出恰当的奖惩制度。本系统我主要设计了登录模块,主模块,考勤管理模块。系统使用 delphi7.0 软件开发工具,sql server 数据库。 关键词:关键词:考勤 考勤统计 考勤查询 模块 第第 1 1 章章 绪绪 论论 1.11.1 课题应用背景课题应用背景 随着信息化的发展,各公司规

11、模的不断扩大,员工管理越来越复杂,考勤的时间又很短,且工作量大, 而考勤管理在公司、企业中起着举足轻重的作用。因为人员考勤管理涉及到工资、福利等与员工个人 利益相关的事物,一个经济实体考勤管理工作的好坏,直接影响到员工主观能动性的发挥,从而影响 到企业的经济利益。 伴随着经济实体的发展壮大公司员工的数量也越来越多。显然,传统的考勤制度。如手工考勤已越 来越不适应时代的发展,使用计算机进行人员考勤管理已经成为一种迫切的需要。 经过我们的详细的调查,目前,许多单位员工考勤还停留在人工管理的基础上,这样的管理方法浪费 许多人力和物力,随着科学技术的不断提高这种传统的手工管理方法必然被以计算机为基础的

12、信息管理 方法所取代. 使用计算机进行管理不仅可以降低管理工作的难度,也可以减少错误和提高效率.因此,开发一套能 够为公司提供充足的信息和快捷的查询手段的考勤管理,是非常必要的. 本设计是从西安华龙公司的实际考勤业务需求出发,针对该公司人工考勤管理的现状,经过详细的 系统调查,为该公司设计同时又有较强的通用性的前提下开发出的一个使用的智能卡考勤系统管理系 统。 1.21.2 现有产品和存在问题现有产品和存在问题 目前市场上,考勤系统已经有很多产品的存在,据我们调研分析,当前的考勤状况非常混乱,高低 不齐。有的大公司,有着良好的智能化考勤系统;而有的中小公司的考勤系统不是智能化不强,就是 有设备

13、不用,随意性较强。小公司则更加混乱。 目前市场上所使用的考勤管理系统有以下三类: 1、人工管理系统 完全的人工管理,员工每次上班都以签名的方式进行登记,这种管理系统是最原始的管理方法, 基本上已被社会所淘汰,但一些小单位仍在使用。 2、指纹考勤管理系统 指纹考勤管理系统,在一些安全性要求较高的地方有较多应用。在员工考勤系统中,这是较为新 型的产品。 指纹考勤管理系统是利用人的指纹作为身份唯一识别。硬件是一智能考勤机作为前台,电脑作为 后台信息处理,先对员工指纹进行采样库存。考勤时对员工指纹与指纹库进行比较。当确认以后,记 录员工的出勤时间、日期、后台管理系统进行核对操作。 指纹考勤系统的缺点:

14、利用指纹考勤,理论上是可行的,杜绝了代打卡现象。但实际应用中,有 一些人员指纹无法识别,并且会出现“误判”现象,此外对光线、温度、湿度的要求也比较严格,适 应性差。 3、纸卡考勤系统 纸卡考勤系统是半机械化半人工的考勤系统。其特点是价格底,但要求人进行统计和核算。纸卡 机的工作原理是利用一个纸卡机,员工用属于自己的纸卡在“统计卡”上打上时间,记录上下班时 间。统计卡是消耗品,目前此系统存在的问题是:代打卡现象极为严重,且需专人看管。但投入成 本底。 纸卡机属于较早的一代考勤系统,十分浪费人力,并没有在真正意义上实现信息化,是面临淘汰 的产品,但目前仍被使用。 4、智能磁卡考勤系统 智能磁卡考勤

15、系统是一个磁卡机和电脑相连,这是真正信息化的考勤系统。有着良好的管理功能, 直接对信息进行管理,如统计、打印、修改等。它的工作原理是:利用员工每个人都有一个电脑能够 唯一识别的字串,代表个人的唯一编码。电脑以此作为对员工工作的唯一识别和记录处理。虽然,磁 卡机考勤系统有着极方便的管理能力。但代打卡现象仍然很严重。 智能磁卡是真正意义上的数字化考勤,但仍需改进其不足之处。 ,智能磁卡考勤系统,较适应大中 型企业,有较大的处理和管理功能。 1.31.3 本选题可行性及现实意义本选题可行性及现实意义 通过调研,目前市场上的其它各种考勤系统与智能卡考勤系统相比,无一例外地存在不足。市场 上的纸卡机考勤

16、系统仍在使用但面临淘汰;指纹考勤系统技术和硬件设备还有待提高。智能磁卡考勤 系统是最主流的考勤设备。所以说,智能磁卡考勤系统是具有成熟的市场和技术的!就开发时间短、 开发风险小、开发成本底、适用性强等特点,这都是纸卡、指纹考勤系统所不能比拟的,研究和设计 它还是有很强的实用性的。 智能磁卡考勤系统采用 delphi 数据库开发技术和射频磁卡技术开发。与其他考勤系统相比具有以 下几个优点: 1、适应性范围广。智能磁卡考勤系统不受温度、光线等环境条件的限制;另外,采用 delphi 数 据库开发技术,支持网络传输,不受距离限制。 2、管理功能强大。用 delphi 开发的考勤管理系统具有强大的数据

17、库管理功能和可维护性。大大 的降低了工作员的工作量和操作难度。 3、成本低。由于软件易于操作,大大降低了软件开发成本和维护费用。硬件采用较为成熟的射频 卡技术:磁卡机为 500-800 元,每张磁卡为 6-8 元。 本课题组以 “智能卡智能考勤系统设计”为题,在指导老师的指导下,初步开发相关的应用程序,解决传统考 勤的不足。这对于我们深入理解所学知识,提高综合应用能力,无疑具有很大的现实意义。 1.4 课题的制作 第第 2 2 章章 需求分析需求分析 需求分析是进行系统开发的基础。通过需求分析,可以明确用户需求,确定 系统功能。具体而言,我们从如下几个方面进行了分析: 2.1 功能需求分析功能

18、需求分析 功能需求主要是为了明确所开发的软件必须具备的功能。考勤是相对繁琐的 工作,公司每天都要对员工进行考勤,员工上班时在考勤系统上登陆,下班时进 行注销,系统会自动记录,这样可以节省许多时间。当员工不能正常上班时,如 出差、请假等,可以给系统操作员说明原因,然后在考勤系统上进行记录,在每 个月进行结算工资是根据考勤系统的记录来增减个人薪金。 考勤信息的来源,可以直接由考勤人员手工输入,也可以由每个员工登陆考 勤系统,进行注册。当然还有其他方式进行考勤信息输入。在本文所阐述的系统 中,所有员工都通过智能卡识别来进行登陆和注销,同时系统需要密码才能进入。 每个员工的智能卡信息已通过采集,转化为

19、数据信息,每次智能卡识别将激活系 统的考勤资料输入模块。这个模块也可以用手工输入,以备例外情况。 根据分析,在本系统中,我们需要实现以下一些基本功能: (1)员工管理:可以添加、删除、查询、修改员工的基本资料。 (2)帐户管理:系统管理员可以添加、删除、查询系统操作员,并指定各操 作人员的权限(权限管理) 。 (3)考勤管理:系统操作员可以设置上下班时间,并能对出差、加班、请假 信息进行添加,修改和删除。 (4) 。考勤统计管理:操作员可以对员工的考勤资料进行统计,并可产生报 表;员工也可以登陆系统查询个人考勤资料。 (5)数据库备份:对现有的数据库进行管理,包括数据库压缩、备份和恢复, 以方

20、便用户对数据库的管理和维护工作 (6)数据查询:可以对员工信息进行查询,也可以对统计信息进行按条件查 询。包括迟到、早退、缺勤、信息,出差信息,加班信息和请假信息的查询。 (7)打印输出:可以对统计信息,查询信息产生报表并进行打印输出 2.2 软硬件分析软硬件分析 智能磁卡考勤系统采用 delphi 数据库开发技术和射频磁卡技术开发。与其他 考勤系统相比具有以下几个优点: 1、适应性范围广。智能磁卡考勤系统不受温度、光线等环境条件的限制;另 外,采用 delphi 数据库开发技术,支持网络传输,不受距离限制。 2、管理功能强大。基于 delphi的考勤管理系统具有强大的数据库管理功能和 可维护

21、性。大大的降低了工作员的工作量和操作难度。 3、成本低。由于软件易于操作,大大降低了软件开发成本和维护费用。硬 件采用较为成熟的射频卡技术:磁卡机为 500-800 元,每张磁卡为 6-8 元。硬件 成本较低,且采用非接触式射频技术,硬件属于非易耗品。 2.3 运行环境要求运行环境要求 系统的运行对运行环境还有一些要求: 1、硬件环境: 处理器:intel pentium 166mx 或更高; 内存:至少 64mb 建议 128mb 或更多; 硬盘:1gb; 显卡:svga 显示适配器; 2、软件环境: 操作系统:windows98/2000/me/xp 数 据 库:microsoft sql

22、 server 软件开发工具:delphi7.0 第第 3 3 章章 概要设计与详细设计概要设计与详细设计 3.1 系统设计原则系统设计原则 在当前诸多条件制约下,首先要研究智能考勤系统的实用性,使用户真正得 到效益,充分发挥它的作用。同时又要注重它的科学性,以促进管理的现代化。 智能考勤系统开发的原则如下: 1、可行性原则。系统要保证技术上的可靠性和经济上的可行性。计算机系统、 通讯网络系统设计和数据设计,在技术上必须是成熟的,经实践检验是成功的, 在经济上是可能实现的。 2、适应性原则。系统要保证可扩展性、可维护性。系统软、硬件都要有扩充 升级的充分余地,系统要便于维护,系统对用户的需求要

23、有一定的适应能力。 3、安全性及保密性原则。智能考勤系统是实现薪金结算的基础,如果哪一个 环节出现问题,例如系统操作员数据泄密,可能会导致财务结算系统混乱,后果 不堪设想。因此,必须设置用户权限,以保证系统有较好的安全性,同时,系统 也应有较强的数据备份和数据恢复功能。 4、人机结合原则。人工信息收集系统与计算机管理信息系统要紧密结合。完 整、准确、及时的信息是信息系统运行的基础。计算机系统是提供信息处理及辅 助决策的技术手段,人工系统与计算机系统要有机的结合,友好的人-机界面是 系统设计的主要原则之一。 5、系统工程原则。系统调查、系统分析、系统设计、软件开发以及实施都要 遵照系统工程的方法

24、和步骤一步一步地进行,以便确保系统的整体性。 6、统一规划、分期实施、逐步完善原则。管理信息系统要按规划、分阶段实 施,由点到面逐步扩充,逐步完善,循序渐进。 3.2 系统功能设计系统功能设计 系统设计是根据需求分析的结果,设计系统的模块和结果之间的内在联系。 3.2.1 系统的功能模块图系统的功能模块图 智能考勤管理系统 管理员身份验证 考勤管理帐户管理 考 勤 管 理 数 据 备 份 数 据 查 询 考 勤 统 计 打 印 输 出 员 工 管 理 修 改 密 码 添 加 用 户 删 除 用 户 图图 3-13-1 系统的功能模块图 3.2.2 系统的数据流程图系统的数据流程图 出勤的原始时

25、间记录主要来源于智能卡考勤机,并且以固定格式保存在数据 库中。系统的各部分数据流程图如下所示. 1)出勤管理数据流程图如下所示: 出勤信息 管理员信息 系统管 理员 11 系统 登陆 d1 出勤 信息 12 系统 管 理 d3 员工信息d2 图 3-2 出勤管理数据流程图 (2)添加加班记录数据流图如下所示: 员工信息 系统管 理员 21 系统 登陆 d2 d4加班信息 加班 信息 22 加班 管理 图 3-3 添加加班记录数据流图 (3)添加请假记录录数据流图如下所示: 员工请假信息 系统管 理员 出勤信息 请假 信息 经理 请假 信息 31 请假 批示 d5 32 系统 管 理 d6 31

26、 记录 登记 图 3-4 添加请假记录数据流图 3.2.3 主要的数据字典主要的数据字典 名字:员工编号 描述:唯一的标识员工的关键 域 定义:员工编号6字符6 位置:考勤信息 出差信息 请假信息 加班信息 统计报表 名字:加班表 描述:每天记录员工出勤状态 的表 定义:加班表员工编号日 期加班时间 位置:统计时,将其内容计入 统计表并判断员工状态 图 3-5 员工编号的数据字典 图 3-6 加班表的数据字典 名字:考勤表 描述:每天记录员工出勤状态的 表 定义:考勤表员工编号日期 刷卡时间出入状态 位置:统计时,将其内容计入统 计表并判断员工状态 名字:请假表 描述:记录员工请假信息的表 定

27、义:请假表员工编号开 始时间结束时间描 述 位置:由统计表对其进行统计 图 3-7 考勤表的数据字典 图 3-8 请假表的数据字典 3.2.4 系统的主程序流程图系统的主程序流程图 图 3-9 系统主程序流程图 3.3 各个子模块的功能设计各个子模块的功能设计 3.3.1 用户登录模块用户登录模块 功能:由用户输入用户名和密码。如果用户名和相应密码正确,则根据该用 户的权限类别进行权限设置;若用户名和密码错误,则进行错误提示,且只允许 用户输入 3 次,超过 3 次系统自动退出。系统管理员进入考勤操作主界面。一般 管理员进入一般管理员界面,相应的操作会受到限制。例如:不能添加,删除管 理员,不

28、能修改用户权限。 3.3.2 考勤信息管理模块考勤信息管理模块 功能:本模块主要实现对上、下班时间设置,同时对出勤信息,加班信息, 请假信息,出差信息进行添加、删除、修改等操作。 功能结构图如图 3-10 所示: 考勤管理 上下 班时 间设 置 出勤 管理 请假 管理 加班 管理 出差 管理 添 加 更 改 修 改 删 除 图 3-10 考勤信息管理模块功能结构图 相关数据表: 考勤表,请假表,出差表,加班表。 3.3.3 数据库管理模块数据库管理模块 功能:本模块实现对系统数据库的备份和还原,以防止出现数据丢失等致命 错误。 功能结构图 如图 3-11 所示: 图 3-11 数据库管理模块功

29、能结构图 3.4 硬件单元硬件单元 系统的硬件有射频卡、读卡机、计算机组成。射频卡读/写单元是一个比较 常用的自动控制设备部件这是一种非接触式读/写程序。射频卡读写单元的结构 框图如下: 图 3-12 射频卡读写单元的结构框图 射频卡读/写单元产品采用串口通信技术。射频卡读写单元提供与微控制器 通信的 ttl 通信接口。数据传输采用标准串行方式。主板模块采用四芯排线与外 界相连。排线定义方式如下:(芯片端口向上,面对接口插座)从左到右依次为 vcc,gnd,txd,rxd。 1、射频卡读/写单元特性 (1)具有精简的指令集,可将射频卡基本操作集成几条命令,操作简便。 (2)具有读、写、增、减、

30、初始化射频卡装载密码等功能。 (3)对射频工作的频率为 13.56mhz。 (4)对射频卡的操作距离为 25mm。 (5)数据传输速率 115200bit/s,通信错误侦测。 (6)ttl 通信接口。 (7)单电源供电:+5v。 2、射频卡读/写命令集 (1)loadkey:改变存放于 rf 读写单元内部的授权密码。 (2)read:读出卡片中模块的数据。 (3)write:将数据写入卡片中的模块。 (4)initval:将卡片中某扇区的内容赋予初值,并初始化为可供增减的 模块。 (5)decrement:将卡片中某扇区的内容减去某一数值。 (6)increment:将卡片中某扇区的内容加上某

31、一数值。 3、射频卡读/写单元编程协议 协议规定:该通信数据传输速率 115200bit/s。通信格式为一位起始位,八 位数据位。一位结束位,无奇偶校验位,数据最大长度为 32 字节。 开始通信时,接收机和发送机都处于就绪状态。首先,发送机发送一个起始 信号(stx) ,正常返回一个 dle 信号,之后开始通信,反之,若无应答,重复三 次。三次之后仍无应答则停止,不再通信。 当数据块中的数据为 10h 时将被发送两次。通信数据之间的最大时间间隔 为 0.5s,如果时间间隔大于 0.5s 就认为通信失败。 第第 4 4 章章 开发方法及开发工具简介开发方法及开发工具简介 4.1 开发方法开发方法

32、 目前流行的系统开发方法主要有生命周期法、快速原型法、面向对象开发方 法等,每种方法各有特色。 生命周期法是一种有效、成熟的方法,它对软件生产实现工程化起了重要作 用,但是应用该方法的前提条件是必须确定系统的需求,才能得到预期的正确结 果。对于信息系统来讲,由于其问题空间十分庞大,不论开发者在系统分析时采 用何种严格的方法力争准确地描述用户需求,在系统没有开发到一定程度,用户 对系统的理解达不到一定的程度是无法准确表达出需求的。这并不是说用户需求 捉摸不定。为了解决需求的模糊性和变化性,出现了另一类系统开发方法,即快 速原型法。 快速原型法是在系统分析基础上,由开发者尽快构造出一个应用系统原型

33、, 经用户初步应用,对系统有了一定的认识后,再由系统开发者与用户反复进行交 流,逐步完善达到最终目标。快速原型法不仅是一种方法,更是一种技巧,它可 以运用与系统开发的各个阶段,例如在系统分析阶段用于提炼用户需求,在系统 实现阶段开发软件原型等。 面向对象的开发方法着眼于所研究的问题,对问题空间进行自然分割,识别 其中的对象及其相互联系,建立问题空间的信息模型。其基本思想是把信息系统 本身看成是一系列离散的对象的集合。这些对象即包括数据结构,也包括在这些 数据结构上的操作与行为。各对象之间由事件触发,引发互通消息而实现互操作。 这样设计出的软件必然是模块化的、可重用的、可扩充的和可移植的,克服了

34、过 去由于分析设计与实施割裂所造成的程序编制必须到设计后期才能进行的程序沉 淀现象。面向对象方法的主要优点并不是减少开发时间,它可能比传统的结构化 方法的开发时间还要长一些。它的主要目标是促进未来系统的可重用性,减少后 续阶段的开发量,从而大大提高软件生产率与可维护性。 综观上述各种方法,考虑到信息系统开发过程的顺序性和开发过程的固有特 点,结合实际开发的经验教训,我们认为各种不同的系统开发方法适用于各自不 同的领域。本设计主要采用面向对象的开发方法。 4.2 开发工具开发工具 “智能考勤系统”设计为 client/server 结构的应用程序。客户端采用 delphi7.0 作为前端开发工具

35、,采用ado 设置数据源,后台采用 microsoft sql server 2000 数据库。系统运行的操作系统为 windows98/nt/me/2000/xp。 下面简要介绍各个开发工具。 delphi 被称为第四代程序开发语言,是一种常用的可视化编程工具,集成 了大量的可视化控件,程序员只需要做少量的工作就能完成大量复杂的工作。 同时,delphi 还具有功能强大,运行高效,界面简洁等特点。它与 visual c+ 相比,在功能上豪不逊色,而且更容易掌握;与 visual basic 相比,delphi 具有更强大的功能。可以说 delphi 集合了 visual c+强大的功能和 v

36、isual basic 的操作简便。因此,利用 delphi 编写 windows 开发应用程序十分方便。 delphi7.0 是公司在 2002 年 8 月推出的新版本。与以往的各个版本相比, 不仅继承了功能强大、成熟而丰富的组件,同时又增加了一些新的特性,如企 业应用的 mda 开发,可视化的快速 web 开发,免费的 datasnap 多层应用开发以 及基于 windows xp 的应用。 microsoft sql server 2000 是 microsoft 在 sql server 7.0 基础上推出 的新一代大型电子商务、数据转换服务、数据仓库服务等方面引入了大量新的 特性,为

37、 web 标准提供了大量支持,并为系统管理提供了许多有力的工具。 第第 5 5 章章 数据库设计数据库设计 5.1 数据库设计遵循的一般原则数据库设计遵循的一般原则 数据库设计是构建一个系统的关键。这是因为数据库设计的优劣将直接影响 系统数据的安全性、可靠性。在数据库的设计过程中,需要遵循的一般原则是: (1) 、数据库各表的设计要反映现实中的事物。数据表中的字段类型和大小 要符合使用习惯。 (2) 、减少数据库的冗余和数据的不一致性。数据库应用的一个特点是对数 据库的频繁操作,每次操作可能只会涉及一个表,也可以同时涉及多个表,也 有可能对一个数据表进行多个操作,在这种情况下,由于数据冗余和数

38、据不一 致时,可能会引起错误。 (3) 、要有助于提高数据处理速度。程序访问数据库的速度依赖于硬件的速 度,数据量的大小和数据表设计的优劣,而前两个因素是很难更改的。 (4) 、要保证数据库的安全。安全性是数据库应用软件的重要要求。 5.2 数据库需求分析数据库需求分析 根据数据流程图(图 3-2,3-3,3-4) ,可以列出以下管理系统所需的数据 项和数据结构。 1、 出勤记录:记录号、员工、出入情况、出入时间。 2、 请假记录:记录号、员工、假期起始时间、假期结束时间、请假原由。 3、 加班记录:记录号、员工、加班时间长度、日期。 4、 出差记录:记录号、员工、出差起始时间、出差结束时间、

39、具体描述。 5、 月度考勤统计:记录号、员工、年月、累计正常工作时间、累计请假时间、 累计加班时间、累计出差时间、迟到次数、早退次数、矿工次数。 6、 所需的外部数据支持: (1) 、员工信息:员工号、密码、权限、姓名、部 门、当前状态等。 (2)部门信息:部门编号、名称等。 5.3 数据库概念结构设计数据库概念结构设计 出勤管理系统的 e-r 图: 密码 员工编号 所属部门 图 5-1 出勤管理系统的 e-r 图 请假管理,出差管理,加班管理的概念结构设计基本相同,现举例请假管理 的 e-r 图如下页: 员工姓名 m n n 图 5-2 请假管理系统的 e-r 图 5.4 各数据表的设计各数

40、据表的设计 数据库设计是构建一个系统的关键,根据系统各模块的功能和它们要处理的 数据,可以基本确定数据库中各表的字段结构。 本系统采用 sql server 2000 建立数据库。数据库中表结构设计如下: 表 5-1:attendance 出勤记录表 m n n 1 员工 员工姓名员工地址 密码 记录 系统管理员 用户权限 用户名 操作 出勤信息 员工编号出入状态具体时间 系统管理员 用户权限 用户名 密码 操作 1 员工 员工编号员工地址 所属部门密码 记录 请假信息 员工编号请假开始时间状态 请假结束时间请假缘由 字段名数据类型是否可空说明 id integrenotnull 记录编号(主

41、关键字) person char(6) notnull 员工号(外部关键字) in_outchar(1)notnull 出入情况 io_timedatenotnull 出入时间 表 5-2: leave 请假记录表 字段名数据类型是否可空说明 idintegernotnull 记录编号 person char(6) notnull 员工号 start-timedatenotnull 假期开始时间 end-time datenotnull 假期结束时间 reasonvarchar(10)notnull 请假原由 表 5-3:login 管理员用户表 字段名数据类型是否可空说明 username

42、char(10) not null 用户名 passwd char(10) not null 密码 authority char(10) yes 用户权限 表 5-4 : overtime 加班时间 字段名数据类 型 是否可空说明 idintegernot null 记录编号 person char(6) not null 员工号 wore-hourssmallintnot null 加班时间 wore-datedatenot null 加班日期 表 5-5: errand 出差记录表 字段名数据类型是否可空说明 idintgernotnull 记录编号 person char(6) not

43、null 员工号 start-timedatenot null 出差开始时间 end-timedatenot null 出差结束时间 descriptionvarchar(6)not null 具体描述 表 5-6:person 员工个人信息表 字段名数据类型是否可空说明 id char(6) notnull 员工号(主关键字) passwd char(20) notnull 密码 authority char(1) yes 用户权限 name varchar(10 ) yes 姓名 sex char(1) notnull 性别 birthdaydateyes 生日 departement c

44、har(3) yes 所在部门 job char(3) yes 职务 edulevel char(1) yes 受教育程度 specialty varchar(20 ) yes 专业技能 address varchar(50 ) yes 家庭住址 tel varchar(20 ) yes 联系电话 email varchar(50 ) yes 电子邮箱 state char(1) yes 当前状态(t,f) remark varcha(400 ) yes 备注 表 5-7: derartment 部门信息表 字段名数据类型是否可空说明 id char(3) notnull 部门编号 name

45、varchar(20) not null 部门名称 manager char(6) yes 部门经理 intro varchar(4000 ) yes 备注 表 5-8:counter 计数器表 字段名数据类型是否可空说明 id char(1) not null 计数器编号 counter-valueintegernot null 记数值 description varchar(10 ) yes 描述 5.5 数据库安全数据库安全 用 delphi 的 dbnavigator、table、dataset 组件来实现多客户的程序时,向 主表插入一条新记录,编辑好后直接提交,往往会出现线路被占用不

46、能提交数据 错误。 在数据库中有一个特定的名词“脏数据” ,用来描述那些被某事物变更但是还 没有提交的数据。那么如何解决用户同时访问数据的问题呢?总不能因为并发而 限制用户的操作吧!并发控制的解决方案是“锁(locking) ”和事物。 从数据库的角度来看,锁有两种类型:排它锁(exclusive locks,简称 x 锁)和共享锁(share locks,简称 s 锁) 。x 锁只允许加锁的事物进行操作,其 他事物禁止加锁和任何操作。其他事物必须等待解锁才能继续运行!s 锁可以允 许多个事物同时对数据加锁,如果事物 t 对数据 r 加了 s 锁,那么其他的事物就 不能再对 r 加 x 锁这样

47、可以保证其他事物不能修改 r。另外,还有一个加锁的范 围需要考虑,我们可以进行行加锁,也可以进行表加锁,甚至还可以进行数据库 加锁。加锁的范围越大,那么实现就越简单,开销就越小,数据的并发程序就越 底!反之,如果加锁范围越小,那么实现就越复杂,开销就越大,数据的并发程 序就越高! 一般的,考虑到加锁成本和性能,处理少量数据的事物应该尽可能减少加锁 的作用范围,提高数据的并发程度,应该采用行锁,防止则应该采用表锁等。另 外,当一个事物操作完毕的时候,应尽可能快的解锁。 第第 6 6 章章 实现实现 6.1 用户登陆子模块用户登陆子模块 设置登陆界面是保障系统安全的一种手段,一般的数据库应用系统都

48、需要进 行登陆才能进入系统。在这个模块里,主要处理用户输入的用户名和用户密码, 程序根据用户名和用户密码进行权限判断,并进入不同的操作界面。用户登录模 块的程序流程图如图 6-1 所示: 用户登录界面如图 6- 2 所示: 图 6-1 用户登陆模块程序流程图 图 6-2 用户登录界面 6.2 主功能模块主功能模块 系统的主功能模块界面如下图: 图 6-3 系统主功能界面 主功能界面的formcreat事件代码为: frmsplash:=tfrmsplash.create(application); frmsplash.showmodal; loginfrm:=tloginfrm.create(

49、application); while n=3 then begin messagedlg(您已经登录失败 3 次,程序将终止,mtwarning,mbok,0); close; application.terminate; exit; end else messagedlg(密码错误,请重试,mtwarning,mbok,0); end; 6.3 时间设置模块时间设置模块 考勤系统的时间设置界面如下: 图 6-4 时间设置界面 修改按钮的click事件代码为: var myinifile:tinifile; begin myinifile:=tinifile.create(extractfi

50、lepath(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); myinifile.writestring(workplan,time4,i_time4.text); end; 6.4 考勤管理模块考勤管理模块 单个员工的click事件代码为: begin t_counter.fil

51、ter:=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 then in_out:=o else in_out:=i; io_time:=strtodatetime(i_io_time.text); t_attendance.filtered:=

52、false; t_attendance.open; t_attendance.appendrecord(counter,person_id,in_out,io_time); end; (2)加班记录与请假记录和出差记录模块: 加班记录与请假记录和出差记录模块界面相同如下: 考勤修改的按条件检索的click事件代码为: begin close; filterstr:=; if seek_by_person.checked then filterstr:=person=+seek_person_id.text+; if seek_by_time.checked then begin if leng

53、th(filterstr)0 then filterstr:=filterstr+ and ; filterstr:=filterstr+io_time+seek_start_time.text; filterstr:=filterstr+ and io_time0 then begin filter:=filterstr; filtered:=true; end else filtered:=false; open; end; end; 第第 7 7 章章 测试与调试测试与调试 7.1 测试测试 白盒测试是一种以程序的内部逻辑结构为依据而设计测试用例的方法,因 而又称为结构测试法或玻璃盒测试

54、法。合理的白盒测试就是要选取足够的测试用 例,对源代码实行比较充分的覆盖,以便尽可能多的发现程序中的错误。主要有 两种方法:一种是逻辑覆盖法,另一种称为路径覆盖法。在这里我们采用逻辑覆 盖法。 在开发智能考勤系统的时候,我们对系统使用白盒测试技术进行了全面测试, 采取的具体测试思路是: 1. 菜单项测试:为了保证每一项下拉菜单能正确实现系统设计的功能,我把 考勤系统所需的所有信息按出勤、迟到、早退、出差、请假等分类全部输入到系 统中,并对每一个菜单反复进行增加、删除、修改、打印报表操作,从而保证了 菜单项的正确实现。 2. 数据跟踪:完成菜单项测试后,我对系统内的每一个数据进行了跟踪测试。 例

55、如:对考勤管理的“请假”这一项,我首先给其加一条请假记录:工号: l0002,姓名:刘海柱,和请假起至时间,请假原因等信息后;然后在查询模块 中,分别进行“按工号查询” 、 “按时间查询”和“按时间查询”该项记录;并且 在统计模块中统计“刘海柱”的请假时间、请假次数等依次验证数据流处理的正 确性。 3. 移植测试:我把系统拷贝到其他计算机上运行,看其移植性能和对环境的 要求。 综合测试:在以上测试的基础上对系统功能进行整体的测试,依此来检验系 统功能是否符合设计的要求。 7.2 调试调试 (1)通过以下具体示例对登录模块进行调试,如图 7-1 所示: 图 7-1 登录模块流程图 满足条件覆盖的

56、测试用例如下: 覆盖 方法 测试路径 次数 = 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-f true 退出系统 (2)对考勤管理模块进行调试: 首先是添加考勤记录: 添加数据为:员工编号:l0002,则对应的员工姓名显示为: 刘海柱,选者出入状态:入。点击单个员工按纽,则出勤记录自动 添加一条记录为: 员工编号出入状态时间 l0002i2012-03-16- 8:05 删除记录:选中要删除的记录,点击删除当前记录,则系统自动删除此条记录, 表中不再有相应的记录。 检索记录:可以按照时间或员工编号进行检索。例如:选中时间,输入时间范围, 点击按条件检索,则表中会显示在时间范围内的记录。选中员工,输入员工编号, 点击按条件检索,则表中会显示该员工的记录。 其它添加出差记录,添加请假记录,

温馨提示

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

评论

0/150

提交评论