数据库课程设计文档(学生考勤管理系统C#)(共21页).docx
精选优质文档-倾情为你奉上学 生考勤系统学院:信息技术学院 班级:计算机131班 系统概论学生考勤管理系统作为一个高校的基本管理,是学校对学生工作管理的基本依据。开发考勤管理系统,正是完善高校信息化管理的重要环节。人工考勤已很难满足学校规范化管理的要求,面对庞大的信息量,该方式现存在很多弊端。因此,建立现代化的智能考勤管理系统势在必行。这样也大大减轻了考勤工作人员的工作量,提高了工作效率,使原本复杂和枯燥无味的工作变得简单而轻松。本系统使用的开发工具是Vs 2013,采用sql数据库。实现学生考勤数据采集、数据统计和信息查询,提供教师在线批假,考勤人员即时记录考勤信息,完善学生管理现代化,方便教师统计、考核学生出勤情况,方便学生管理课程查询、考核学生的出勤率,准确地掌握学生出勤情况和相关资料,有效地管理、掌握学生各项情况。目录专心-专注-专业1.需求分析1.1背景分析 如今各大高校已经做到高度信息化管理。师生的成绩查询系统、教务管理系统、招生就业系统等系统在各大高校得到广泛应用,对全校师生的学习、办公、管理带来了便利,因此开发一个学生考勤系统能进一步加强高校学风建设,维护正常的教学秩序。 目前高校学生上课考勤都是由任课教师或学习委员点名,记录学生出勤情况,对于请假,需要得到辅导员或学院领导的批准。这种模式在目前的高校管理中暴露了不可避免的弊端:一、学生请假对任课教师不透明;二、学生对自己整个学期的上课出勤情况没有整体的统计信息;三、学校领导、班主任对学生上课的出勤情况不易整体把握;因此建立一个好的学生考勤系统可以一定程度上解决这些弊端,本系统是主要针对高校学生上课出勤管理及查看而设计的信息系统。本系统涉及高校四大类用户:学生、考勤人员(学习委员)、教师、教务处管理员。1.2功能需求分析1.2.1数据字典字段名类型备注说明能否为空snoChar(12)学生学号否snameChar(20)学生姓名否ssexChar(2)学生性别否sdeptChar(20)学生所属专业否sentrance_timedatetime学生入学年月否spasswordChar(12)学生登陆密码否class_nameChar(20)班级名否class_codeChar(12)班级代码否cnoChar(12)课程号否cnameChar(20)课程名否creditChar(6)课程学分否class_timeChar(12)课程时间否tnnameChar(20)教师姓名否tnoChar(12)教师代码否tsexChar(2)教师性别否tentrance_timedatetime教师入职年月否tdeptChar(20)教师所属系别否troomChar(20)教师所属教研室否ttitleChar(20)教师职称否tpasswordChar(12)教师登陆密码否currentTimedatatime考勤当前时间否Attendance_stateChar(12)出勤状态否Off_startChar(12)请假开始时间否Off_endChar(12)请假截止时间否 1.2.2数据流图根据学生考勤系统的有关功能,进一步形成如图1-2所示的学生考勤管理系统数据流图: 图1-1 学生考勤管理系统数据流图1.2.3功能层次结构根据调查、分析、商讨,最终确定该系统有考勤记录与教师批假管理子系统、出勤情况查询子系统、后台管理子系统三个子系统构成,三个子系统的主要功能如下所述:(1)考勤记录与教师批假管理模块 本模块的功能是实现学生出勤情况的管理与记录以及教师对学生的批假功能,主要涉及两大类用户:考勤人员、教师(包括任课教师、班主任和学校领导),教师可通过此功能模块进行在线批准学生请假;考勤人员可以在登入考勤系统后的看到今日请假的同学名单,然后根据点名情况在线记录本班学生的出勤状况。(2)出勤情况查询模块 本模块的功能是学生考勤情况统计的实现、查看及管理,涉及四类用户:学生、教师(包括任课教师、班主任和学校领导)。学生可在线查看自己所有学年的出勤信息;教师可在线查看某位学生或某门课程的学生出勤情况;(3)后台管理管理 本模块的功能实现整个系统数据的同步更新及维护,只涉及系统教务处管理员用户。教务处管理员动态的管理学生信息、教师信息、课表安排、班级安排等信息,是整个系统实现的基础。(4)最终得到的需求分析层次结构图如1-2所示: 图1-2 需求分析层次结构图1.3系统设计的目标与内容 针对系统来说主要任务是设计一个学生考勤管理系统,实现学生考勤的录入、按学号或课程统计、浏览、查询某学生全部出勤状况。整个考勤系统能够提供请假、迟到、早退、旷课等情况的记录,并实现等处理功能。具体的设计任务如下:1、实现教务处管理人员的用户登录及修改密码及管理和创建用户账户;2、教师(包括班主任、任课教师、校领导)可在线批准学生的请假。当该班级的考勤人员在学生请假日期内登入考勤系统时会将该学生的请假情况显示出来,以便于考勤人员的记录。3、考勤人员登录考勤系统记录当天本班学生的出勤情况。同时也可查看请假学生的具体情况。4、教师可查看某一学生或某门课程的学生出勤状况。5、任课教师能按课程查询统计本课程学生出勤状况。6、学生可通过在线登陆查看自己所有课程的出勤状况。2.概念结构设计2.1概念设计方法本系统先采用自顶向下的设计方法,根据用户需求,先定义全局概念结构的框架,然后分层展开,对学生考勤管理系统的需求进行逐步细化。然后再采用自底向上将各个实体集成、根据用户的每一具体需求,逐步抽象化,最终产生全局概念结构。2.2设计步骤2.1.1局部E-R模型进行局部概念设计,画出主要实体模型如下图所示:2.1.2初步E-R图根据实体之间的联系,得出学生管理系统数据库初步E-R图如下所示:3逻辑结构设计3.1关系模式根据E-R模型中所有实体对应产生如下七个关系模式:学生(学号,姓名,性别,专业,入学年月,密码,班级代码)课程(课程代码,课程名,学分,课程时间,教师代码)教师(教师代码,教师名,性别,入职年月,所属系别,所属教研室,职称,密码)班级选课表(班级代码,课程代码,课程时间)班级表(班级代码,班级名,教师代码)学生个人出勤情况统计表(学号,课程代码,出勤状态,考勤当前时间)批假表(学号,请假开始时间,请假结束时间,批假人)3.2数据库建表建立的数据库表如下所示:表3-1 学生表表3-2 教师表表3-3 课程表表3-4 班级表表3-5 班级选课表表3-6 学生出勤表表3-7 批假表3.3数据库关系图数据库中表之间的联系及参照关系如下图3-1所示: 。 图3-1 数据库表关系图4数据库的物理设计 4.1存储结构域存取方式的选择本程序的数据文件和日志文件都存放在磁盘上。最大的数据空间为200mb。主数据文件增长的最大值为2mb。42约束条件及参照关系4.2.1约束关系(1)出勤状态约束check (attendance_state in('正常','迟到','旷课','早退','请假'),(2)性别约束check(ssex in('男','女')4.2.2参照关系(1)班级选课表参照了班级表中的班级代码和课程表中的课程代码和课程时间foreign key(class_code)references class(class_code),foreign key(cno,class_time)references course(cno,class_time);(2)课程表参照了教师表中的教师代码foreign key(tno) references teacher(tno),(3)出勤状态表参照了学生表的学生代码和课程表的课程代码和课程时间foreign key(sno)references student(sno),foreign key(cno,class_time)references course(cno,class_time)(4)批假表参照了学生表的学生代码foreign key(sno)references student(sno),5数据库的运行与维护51数据库的初始化(包括数据库、表以及视图的建立)(1)创建考勤管理系统create database kaoqinon(name=kaoqin,filename='D:kaoqin.mdf',size=20mb,maxsize=200mb,filegrowth=2mb)log on(name='kaoqin_log',filename='d:kaoqin.ldf',size=10mb,maxsize=100mb,filegrowth=2mb);(2)创建学生表create table student(sno char(12)primary key,sname char(20)not null,ssex char(2)check(ssex in('男','女') not null,sdept char(20)not null,sentrance_time datetime not null,spassword char(12)not null,class_code char(12)not nullforeign key(class_code) references class(class_code)(3)创建课程表create table course(cno char(12),cname char(20)not null,credit char(6)not null,class_time char(12) not null,tno char(12)not nullprimary key(cno,class_time),foreign key(tno) references teacher(tno),);(4)创建班级表create table class(class_code char(12)primary key,class_name char(20) not null,tno char(12) not null,-班主任foreign key(tno) references teacher(tno)-参照教师表);(6)创建教师表 tno char(12)primary key,tname char(20)not null,tsex char(2)check(tsex in('男','女')not null,tentrance_time datetime not null,tpassword char(12)not null,tdept char(20)not null,troom char(20)not null,ttitle char(20)not null);(7)班级选课表create table class_course(class_code char(12) not null,cno char(12)not null,class_time char(12),primary key(class_code,cno,class_time),foreign key(class_code)references class(class_code),foreign key(cno,class_time)references course(cno,class_time);(8)学生个人出勤情况统计表create table attendance(currenttime char(20) not null,class_time char(12),sno char(12)not null,cno char(12)not null,attendance_state char(12) not null,primary key(sno,cno,currenttime),check (attendance_state in('正常','迟到','旷课','早退','请假'),foreign key(sno)references student(sno),foreign key(cno,class_time)references course(cno,class_time)alter table attendanceadd constraint DF_attendance_state default'正常' for attendance_state;(9)建立批假表create table leave(off_start datetime not null,off_end datetime not null,sno char(12) not null,teachername char(20) not null,primary key(sno,off_start,off_end),foreign key(sno)references student(sno),)alter table leaveadd reason varchar(100);(9)创建视图create view attendance_viewasselect student.sno,sname,o,cname,course.class_time,currenttime,attendance_statefrom student ,course,attendancewhere student.sno=attendance.sno and o=o 6系统运行界面展示61考勤人员界面(1)登录界面(2)首页(3)点名窗体(4)查看请假学生具体信息窗体6.2教师窗体(1)查看学生出勤状况窗体(2)教师批假窗体6.3学生窗体(1)查看出勤信息窗体6.4教务管理人员窗体(1)查看界面(2)用户管理界面