oracle专业课程设计.doc
《oracle专业课程设计.doc》由会员分享,可在线阅读,更多相关《oracle专业课程设计.doc(18页珍藏版)》请在咨信网上搜索。
安徽省巢湖学院计算机和信息工程学院 课程设计汇报 课程名称 《oracle数据库》 课题名称 学生考勤系统 专业班级 11计科工程2班 学 号 11011119 姓 名 卢思露 联络方法 指导老师 邢慧芬 完成日期: 年 1 月 4 日 1学生考勤管理系统背景分析 3 2学生考勤管理系统需求分析 3 2.1 用户需求描述 3 2.2.1学生用户需求描述 3 2.2.2任课老师用户需求描述 4 2.2.3班主任用户需求描述 4 2.2.4院系领导用户需求描述 4 2.2.5学校领导用户需求描述 4 2.2.6系统管理员用户需求描述 4 2.3功效需求描述 5 2.4系统功效划分 5 2.4.1 请假系统模块 5 2.4.2 考勤系统模块 5 2.4.3 后台管理管理 5 3学生考勤系统E-R模型 6 4数据字典设计 7 5数据库表逻辑结构设计 8 6数据库表空间和表设计 10 6.1、设计表空间 10 6.2、创建表 11 6.3、创建其它数据库对象 14 7心得体会 15 8参考文件 15 Oracle数据库课程设计 ——学生考勤系统Oracle实现 1学生考勤管理系统背景分析 伴随高校校园信息化逐步完善,有效地借助网络、数据库等技术提升工作和管理效率。现在针对师生成绩查询系统、教务管理系统、招生就业系统、BBS、校园网站等系统在各大高校纷纷出现,对全校师生学习、生活、管理、办公带来了便利。所以学生考勤管理系统能深入加强高校学风建设,维护正常教学秩序,给学生发明一个优良学习环境。 现在高校学生上课考勤管理全部是以任课老师上课点名,统计学生上课情况,对于时间比较长请假,需要经过递交请假申请让班主任、院系领导全部同意方能生效。这种模式在现在高校管理中暴露了不可避免弊端: 1、学生请假不方便; 2、学生请假对任课老师不透明; 3、学生对自己整个学期上课出勤情况没有整体统计信息; 4、班主任对本班学生整个学期上课出勤情况不易查看; 5、院系领导、学校领导不轻易把握学生上课出勤情况。 所以一个好学生考勤管理系统在一定程度上能够处理这些弊端,本系统关键针对现在高校学生在线请假和学生上课出勤管理而设计信息系统。本系统包含到高校六大类用户:学生、任课老师、班主任、院系领导、学校领导、系统管理员。 2学生考勤管理系统需求分析 2.1 用户需求描述 用户是系统最终使用者,依据分析,本系统应该包含学生、班主任、任课老师、院系领导、学校领导、系统管理员六类用户,这六类用户对系统需求简明概括以下: 2.2.1学生用户需求描述 学生对本系统关键需求是:在线请假和查看在校期间全部上课出勤信息。 在线请假需求:学生请假全过程当中,学生能够随时查看请假具体进展情况。 查看出勤信息需求:学生能够查看在校期间全部学期上课出勤具体信息,如:查看“Oracle数据库管理和应用”这门课程在整个学期请假、旷课多少次等信息。 其它需求:查看本人基础信息,如本人所属院系、年级、专业、班级、学号、姓名、性别等,和修改个人用户密码。 2.2.2任课老师用户需求描述 任课老师对系统关键需求是:管理所教班级学生上课出勤信息和查看所教班级学生上课出勤信息。 管理学生上课出勤需求:伴随时间改变,自动列出还没有在网上公布学生上课出勤信息,系统自动依据学生请假系统,决定学生上课出勤最终止果。 查看学生出勤信息需求:查看所教班级学生整个学期出勤情况。 其它需求:本人基础信息和修改个人用户密码。 2.2.3班主任用户需求描述 班主任对本系统关键需求是:审批本班学生本学期在线请假和查看本班学生本学期全部课程上课出勤信息。 审批学生请假需求:本班学生本学期在线请假申请后,自动提醒班主任有等候审批请假信息,班主任针对请假申请信息进行学生请假审批。 查看学生上课出勤信息需求:查看本班学生整个学期相关课程出勤统计信息及具体信息。 其它需求:查看本班学生基础信息、修改个人用户密码等。 2.2.4院系领导用户需求描述 院系领导对系统关键需求是:审批本院系学生超出三天请假和查看本院系学生上课出勤信息。 审批请假需求:当学生请超出三天假,经班主任审批同意后,系统自动提交给任何一个进入系统院系领导审批请假。 查看本院系学生出勤信息需求:输入查询条件后,系统依据查询条件列出本院系学生相关上课出勤信息。 其它需求:查看本院系相关基础信息和修改个人用户密码等。 2.2.5学校领导用户需求描述 学校领导对系统关键需求是:查看全校学生上课出勤信息。 查看出勤信息需求:输入查询条件后,系统依据查询条件列出本校学生相关上课出勤信息。 其它需求:查看相关全校基础信息以信修改个人用户密码等。 2.2.6系统管理员用户需求描述 系统管理员有系统最高权限,负责系统所需全部数据动态同时更新和维护,依据系统针对各用户设计,基础功效需求以下: 1、管理学校各院系、年级、专业、班级添加、删除、修改等。 2、管理每个学期每个班级课程安排及指定班主任和任课老师。 3、管理系统全部用户。 4、管理全校课表安排。 5、管理系统请假、考勤信息。 2.3功效需求描述 依据各类用户需求描述,系统应该含有请假系统、考勤管理系统、后台管理系统这三大关键功效。 请假系统功效需求:经过班主任和院系领导同意请假信息。请假最长时间不能超出1个月,特殊情况除外。 考勤管理功效需求:任课老师经过考勤管理系统,对学生上课出勤信息进行公开。请假系统要借助班主任才能完成,考勤管理系统要借助请假系统、班级课表安排才能完成,然而每年课表全部在改变,班主任安排也有在改变,学生也在改变,所以必需要求后台管理系统能依据系统需求,动态、正确更新系统数据。 2.4系统功效划分 依据系统用户需求,将本系统按功效划分成三大功效模块:请假系统、考勤系统、后台管理模块,包含到六大类用户:学生、任课老师、班主任、院系领导、学校领导、系统管理员。 2.4.1 请假系统模块 本模块功效是在线请假实现及管理,关键包含三大类用户:学生、班主任及院系领导用户,学生经过此功效模块进行在线请假及查看请假统计信息;班主任在线审批学生请假及查看请假统计信息;院系领导在线审批学生长时间请假及查看请假统计信息。 2.4.2 考勤系统模块 本模块功效是学生考勤信息统计实现、查看及管理,包含六大类用户中全部用户。学生在线查看自己全部年出勤信息;任课老师在线管理学生出勤信息;班主任、院系领导、学校领导查看不一样范围学生出勤信息。 2.4.3 后台管理管理 本模块功效实现整个系统数据同时更新及维护,只包含系统管理员用户。系统管理员动态管理学生信息、课表安排、年安排等信息,是整个系统实现基础。 3学生考勤系统E-R模型 n 1 n 1 n m n 1 n 1 m 1 n n n 1 老师 班级 学生 学院领导 学院 专业 课程 假条 开设 考勤 属于 属于 讲课 聘用 班主任 管理 请假 学号 姓名 性别 班级 专业 院系 编号 名称 编号 专业名称 所属学院 编号 姓名 性别 所属院系 课程号 课程名 课程性质 编号 名称 编号 姓名 性别 所属院系 职称 编号 姓名 性别 所属专业 所属学院 班主任 编号 学号 …… 原因 4数据字典设计 名字:管理员信息 描述:每一位管理员具体信息 定义:管理员信息=编号+姓名+性别+职称+密码 名字:学院领导信息 描述:每一位学院领导具体信息 定义:学院领导信息=编号+姓名+性别+职称+所属学院 名字:院系信息 描述:每一个学院具体信息 定义:院系信息=编号+院系名称 名字:专业信息 描述:每一位管理员具体信息 定义:专业信息=编号+姓名+所属院系 名字:课程信息 描述:每一门课程具体信息 定义:课程信息=课程号+课程名+课程性质 名字:老师信息 描述:每一位老师具体信息 定义:老师信息=编号+姓名+性别+所属院系 名字:班级信息 描述:每一个班级具体信息 定义:班级信息=编号+班级名称+班主任 名字:班主任信息 描述:每一位班主任具体信息 定义:班主任信息=编号+姓名+性别+所属学院+所属专业 名字:学生信息 描述:每一位学生具体信息 定义:学生信息=学号+姓名+性别+专业+院系+班级 名字:请假条信息 描述:每一请假条具体信息 定义:请假条信息=请假代号+班级代号+学生学号+请假原因+开始时间+结束时间+请假天数+申请请假时间+班主任审批状态+班主任审批时间+院系领导审批状态+院系领导代号+院系领导审批时间 5数据库表逻辑结构设计 (1)系统管理员表admin 字段名 数据类型 可否为空 键引用 备注 admin_no char(5) 否 主键 管理员编号 admin_name char(10) 否 管理员姓名 admin_sex char(2) 否 性别 admin_title char(20) 否 职称 admin_password varchar2(20) 否 登入密码 (2)学生表student 字段名 数据类型 可否为空 键引用 备注 stu_no char(10) 否 主键 学生学号 stu_name varchar(30) 否 学生姓名 stu_sex char(2) 否 性别 stu_class char(13) 否 外键 所属班级 stu_major char(30) 否 外键 所属专业 stu_faculty char(40) 否 外键 所属学院 (3)院系表faculty 字段名 数据类型 可否为空 键引用 备注 faculty_id number 否 主键 院系编号 faculty_name char(20) 否 院系名称 (4)专业表major 字段名 数据类型 可否为空 键引用 备注 major_id number 否 主键 专业编号 major_name char(20) 否 专业名称 major_faculty number 否 外键 所属院系 (5)老师表teacher 字段名 数据类型 可否为空 键引用 备注 tea_no char(10) 否 主键 任课老师编号 tea_name char(20) 否 任课老师姓名 tea_sex char(2) 否 性别 tea_faculty number 否 外键 所属学院 (6)班主任表classteacher 字段名 数据类型 可否为空 键引用 备注 classtea_no char(5) 否 主键 任课老师编号 classtea_name char(20) 否 任课老师姓名 classtea_sex char(2) 否 性别 classtea_major number 否 外键 所属专业 classtea_faculty number 否 外键 所属学院 (7)院领导表collegeleader 字段名 数据类型 可否为空 键引用 备注 collegeleader_no char(5) 否 主键 学院领导编号 collegeleader_name char(20) 否 学院领导姓名 collegeleader_sex char(2) 否 性别 collegeleader_faculty number 否 外键 所属学院 title char(20) 否 职称 (8)学校领导表schoolleader 字段名 数据类型 可否为空 键引用 备注 schoolleader_no char(5) 否 主键 学校领导编号 schoolleader_name char(20) 否 学校领导姓名 schoolleader_sex char(2) 否 性别 dept char(20) 否 所属部门 title char(25) 否 职称 (9)学生上课出勤统计表kaoqin_record 字段名 数据类型 可否为空 键引用 备注 kaoqin_id char(13) 否 主键 上课出勤编号 sk_time datetime 否 上课时间 stu_number char(10) 否 外键 学生学号 stu_status char(10) 否 学生上课考勤状态 teacher_no char(10) 否 外键 老师编号 course_no char(13) 否 外键 课程编号 (10)课程信息表course 字段名 数据类型 可否为空 键引用 备注 course_no char(13) 否 主键 课程编号 course_name char(20) 否 课程名称 course_xz char(4) 否 课程性质 (11)班级表classes 字段名 数据类型 可否为空 键引用 备注 class_no char(10) 否 主键 课程编号 class_name char(20) 否 课程名称 classtea_no char(5) 否 外键 课程性质 (12)请假信息表qingjia 字段名 数据类型 可否为空 键引用 备注 id number 否 主键 请假代号 class_id char(10) 否 外键 班级代号 stu_no varchar2 (20) 否 外键 学生学号 leave_reason varchar2 (200) 否 请假原因 start_time datetime 否 开始时间 end_time datetime 否 结束时间 day_number number 否 请假天数 qingjia_time datetime 否 申请请假时间 class_tea_id char(5) 否 外键 class_tea_sp_status char(10) 否 班主任审批状态 class_tea_sp_time datetime 否 班主任审批时间 coll_leader_sp_status char(10) 否 院系领导审批状态 coll_leader_id char(5) 否 外键 院系领导代号 coll_leader_sp_time datetime 否 院系领导审批时间 备注:status 表示审批状态:0为等候审批,1为同意请假,2为不一样意请假。 6数据库表空间和表设计 6.1、设计表空间 创建通常字典管理类表空间,目标是为了方便利用SQL字典跟踪磁盘使用情况。 使用以下命令创建表空间: create tablespace linpeng_data datafile ‘/u01/oracle/oradata/tab01.dbf’ size 100M default storage(initial 512K next 128K minextents 2 maxextents 999 pctincrease 0) online; 6.2、创建表 1、创建系统管理员表admin create table admin ( admin_no char(5) not null, admin_name char(10) not null, admin_sex char(2) check (admin_sex='男' or admin_sex='女'), admin_title char(20) not null, admin_password varchar(20) not null, constraint pk_admin primary key (admin_no) ) tablespace linpeng_data; 2、学生表student create table student ( stu_no char(10) not null, stu_name varchar(30) not null, stu_sex char(2) check (stu_sex='男' or stu_sex='女'), stu_class char(5) foreign key references classes(class_no), stu_major number foreign key references major(major_id), stu_faculty number foreign key references faculty(faculty_id), constraint pk_student primary key(stu_no) ) tablespace linpeng_data; 3、院系表faculty create table faculty ( faculty_id number not null, faculty_name char(10) not null, constraint pk_faculty primary key (faculty_id) ) tablespace linpeng_data; 4、专业表major create table major ( major_id number not null, major_name char(10) not null, major_faculty number foreign key references faculty(faculty_id), constraint pk_major primary key (major_id) ) tablespace linpeng_data; 5、老师表teacher create table teacher ( tea_no char(10) not null, tea_name char(20) not null, tea_sex char(2) check (tea_sex='男' or tea_sex='女'), tea_faculty number foreign key references faculty(faculty_id), constraint pk_teacher primary key (tea_no) ) tablespace linpeng_data; 6、班主任表classteacher create table classteacher ( classtea_no char(5) not null, classtea_name char(20) not null, classtea_sex char(2) check (classtea_sex='男' or classtea_sex='女'), classtea_major number foreign key references major(major_id), classtea_faculty number foreign key references faculty(faculty_id), constraint pk_classteacher primary key (classtea_no) ) tablespace linpeng_data; 7、院领导表collegeleader create table collegeleader ( collegeleader_no char(5) primary key, collegeleader_name char(20) not null, collegeleader_sex char(2) check(collegeleader_sex in('男','女')), collegeleader_faculty number foreign key references faculty(faculty_id), title char(20) not null ) tablespace linpeng_data; 8、学校领导表schoolleader create table schoolleader ( schoolleader_no char(5) primary key not null, schoolleader_name char(20) not null, schoolleader_sex char(2) check(schoolleader_sex in('男','女')), dept char(20) not null, title char(20) not null ) tablespace linpeng_data; 9、学生上课出勤统计表kaoqin_record create table kaoqin_record ( kaoqin_id char(13) primary key not null, sk_time datetime not null, stu_number char(10) foreign key references student(stu_no), stu_status char(10) not null, teacher_no char(10) foreign key references teacher(tea_no), course_no char(13) foreign key references course(course_no) ) tablespace linpeng_data; 10、课程信息表course create table course ( course_no char(13) primary key, course_name char(20) not null, course_xz char(4) not null ) tablespace linpeng_data; 11、班级表classes create table classes ( class_no char(10) primary key, class_name char(20) not null, classtea_no char(5) foreign key references classteacher(classtea_no) ) tablespace linpeng_data; 12、请假信息表qingjia create table qingjia ( id number primary key, class_id char(10) foreign key references classes(class_no), stu_no char(10) foreign key references student(stu_no), leave_reason varchar2(200) not null, start_time datetime not null, end_time datetime not null, day_number nubmer not null, qingjia_time datetime not null, class_tea_id char(5) foreign key references classteacher(classtea_no), class_tea_sp_status char(10), class_tea_sp_time datetime, coll_leader_sp_status char(10), coll_leader_id char(5) foreign key references collegeleader(collegeleader_no), coll_leader_sp_time datetime ) tablespace linpeng_data; 6.3、创建其它数据库对象 1、创建存放过程用于统计学生查询某门课程出勤情况 create or replace procedure getMessage(stu_no in varchar2, course_no in varchar2, total_times out number) as absence_times number; begin select count(*) in to absence_times from kaoqin_record where stu_number=stu_no and course_no=course_no; total_times=absence_times; end; 2、创建视图,使不一样院系领导只能查询到自己学院学生上课考勤信息,假设软学院ID为5,以下代码为创建一个用于给软件学院领导查看本学院学生考勤信息视图。 create view rjxy as select kaoqin_record.kaoqin_id,kaoqin_record.sk_time,kaoqin_record.stu_number,kaoqin_record.stu_status,kaoqin_record.teacher_no,kaoqin_record.course_no from kaoqin_record,student where student.stu_no=kaoqin_record.stu_number and student.stu_faculty=5; 3、创建触发器,当某学生某课程缺勤次数超出一定次数时给出提醒信息 create or replace trigger alertMessage after insert on kaoqin_record for each row declare current_times number; begin select count(*) into current_times from kaoqin_record where stu_number=:new.stu_number and course_no=:new.course_no; if(current_times >= 3) then dbms_output.put_line('学号为:' || :new.stu_number || '学生该门课程被取消考试资格!'); end if; end; 7心得体会 经过此次Oracle数据库课程设计,将本学期所学Oracle知识及数据库基础方面知识得到了一综合性应用,使我基础掌握了在软件项目标开发过程中数据库设计基础步骤,从需求分析到数据库逻辑结构设计,再到数据库物理结构设计等。 为了提升系统效率和可靠性,部分比较关键功效全部采取存放过程或函数封装在数据库端,在其它程序设计语言中直接调用 8参考文件 [1] 王永贵.《Oracle数据库管理和应用》.中国矿业大学出版社. [2] 赵文涛,数据库系统原理,中国矿业大学出版社, [3] 安葳鹏,软件工程,中国矿业大学出版社, [4] 张晓东 ,JSP+Oracle数据库开发和实例, 清华 大学出版社 [5] 向隅编 数据库基础及应用 邮电大学 出版社- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- oracle 专业课程 设计
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【w****g】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【w****g】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【w****g】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【w****g】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文