欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年2022年教务管理信息系统的数据库设计实例 .pdf

    • 资源ID:39711713       资源大小:137.73KB        全文页数:12页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年2022年教务管理信息系统的数据库设计实例 .pdf

    *大学本科生设计性实验报告课程名称:数据库系统实验项目名称:教务管理信息系统数 据 库 设 计学生:姓名学号班级*班第组*至*学年 第*学期*年*月*日名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 12 页 -1.引言制作教务管理信息系统的目的是为学校学生提供一个方便创建教师、学生信息的工具,实现能够方便、快捷的查询信息。本系统功能概述:(1)管理员通过后台数据库管理系统插入、修改、删除课表,并把相应信息保存到数据库中。(2)用户浏览所有挂牌课课程,教师,学生的信息。(3)用户查询课程,系统输出该课程所有信息。(4)双击某门课程,即选中该门课,把这门课放到课表里(5)统计已选课程的学分。(6)根据用户查询的课程,系统排列出所有课表并输出。(7)用户增加、修改、删除查询的课程,系统从新排列所有课表并输出。(8)若管理员/用户输入信息有误,系统报错。1.1 编写目的管理信息系统是进行信息的采集,存储,修改,维护,备份和使用的系统,它是随着管理科学和技术科学的发展而形成的.教务管理信息系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要,所以教务管理信息系统应该能够为用户提供充足的信息和快捷的查询手段,对学生来说可以轻松的查阅自己在校的信息以及选课等。1.2 背景项目名称:教务管理信息系统(Educational administration information system简称 EAIS)。项目提出者:EAIS 项目组织人员。项目开发者:EAIS 项目开发小组。项目鉴定者:*老师和各位同学。项目开始时间:*。1.3 定义列出本文件中用到的专门术语的定义和缩写词的源词组。1.所有的表名的命名规则:用该表的英文含义,首字母必须大写,如学生表:Student.2.所有的主键命名规则:用“表名_PK“表示.3.所有外键的命名规则:用”本表名 _FK”表示.4.所有规则的命名规则:用具有实际含义的英文单词组成.5.所有索引的命名规则:用“表名_IX“表示.6.所有字段的命名规则:用具有实际含义的英文单词组成.7 所有的触发器名用”表名+Update/Insert/Delete”组成.8.所有的变量、属性、约束和规则必须给出详细的注解.9.所有的存储过程用pro+具有实际含义的英文单词组成.名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 12 页 -10.所有的函数名用fun+具有实际含义的英文单词组成.2.数据字典2.1 学院表 Depart 用于说明学院基本信息中的记载2.1.1 字典结构属性名称属性类型是否允许空默认值约束含义DepartmentNo Char(3)NOT NULL主键学院编号DepartmentName Varchar2(30)NULLunique 学院名称Manager Varchar2(20)NULL院长Telephone Varchar2(20)NULL办公室电话2.2 班级表 Class 用于记载班级基本信息2.2.1 字典结构属性名称属性类型是否允许空默认值约束含义ClassNo Char(5)NOT NULL主键、届数流水号班级编号ClassName Varchar2(30)NULLunique 班级名称TeacherNo Char(8)NULL外键班主任编号MonitorNo Char(8)NULL外键班长编号DepartNo Char(3)NOT NULL外键学院编号2.3 学生表 Student 用于存储学生基本信息2.3.1 字典结构属性名称属性类型是否允许空默认值约束含义StudentNo Char(8)NOT NULL主键、届数流水号学号StudentName Varchar2(20)NOT NULL学生姓名Sex Varchar2(2)NULL“男”只取“男”、“女”性别DepartmentNo Char(3)NOT NULL外键学院编号ClassNo Char(5)NOT NULL外键班级编号BirthdayDate date NULL出生日期FamilyAddress Varchar2(30)NULLunique 家庭地址QQ Varchar2(20)NULLunique QQ 号码Telephone Varchar2(20)NULLunique 移动电话StudentImage blob NULL相片StudentMemo Varchar2(300)NULL/*备注*/2.3.2 索引create index Student_IX on Student(StudentNo)pctfree 30 tablespace MyspaceIndex;2.4 教师表 Teacher 名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 12 页 -用于存储教师基本信息2.4.1 字典结构属性名称属性类型是否允许空默认值约束含义TeacherNo Char(8)NOT NULL主键教师编号TeacherName Varchar2(20)NOT NULL教师姓名Sex Varchar2(2)NULL“男”只取“男”、“女”性别Position Varchar2(20)NULL职称Telephone Varchar2(20)NULL移动电话DepartmentNo Char(3)NOT NULL学院编号TeacherMemo varchar2(1000)NULL/*备注*/2.4.2 索引create index Teacher_IX on Teacher(TeacherNO)pctfree 30 tablespace MyspaceIndex;2.5 学生选课表 Student_Coursing 用于存储学生所选的课基本信息2.5.1 字典结构属性名称属性类型是否允许空默认值约束含义StudentNo Varchar2(9)NOT NULL主键学号CourseNo Varchar2(6)NOT NULL课程代码CourseNameVarchar2(20)NOT NULL课程名称TeacherNo Varchar2(9)NOT NULL教师编号2.6 课程表 Course 用于存储管理员创建的课程基本信息2.6.1 字典结构属性名称属性类型是否允许空默认值约束含义CourseNo Char(5)NOT NULL主键课程代码CourseName Varchar2(20)NULL课程名称Grades Char(1)NULL学分ClassLeaves Char(3)NULL班别SchoolHours Char(5)NULL上课时间TeacherName Varchar2(20)NULL教师姓名Position Varchar2(20)NULL职称Capacity Char(3)NULL容量2.7 用户权限表 PrivilegeUsers 用于定义用户角色基本信息2.7.1 字典结构属性名称属性类型是否允许空默认值约束含义PrivilegeCode Char(1)NOT NULL主键权限代码UserName Varchar2(80)NOT NULL用户名称2.8 超级管理员登陆表Super_Login 用于存储管理员的编号和密码名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 12 页 -2.8.1 字典结构属性名称属性类型是否允许空默认值约束含义SuperNo Char(8)NOT NULL主键管理员编号Password Char(10)NOT NULL密码PrivilegeCode Char(1)NOT NULL权限代码2.9 学生登陆表 Student_Login 用于存储学生的编号和密码2.9.1 字典结构属性名称属性类型是否允许空默认值约束含义StudentNo Char(8)NOT NULL主键学号Password Char(10)NOT NULL密码PrivilegeCode Char(1)NOT NULL权限代码3.0 教师登陆表 Teacher_Login 用于存储教师的编号和密码3.0.1 字典结构属性名称属性类型是否允许空默认值约束含义TeacherNo Char(8)NOT NULL主键教师编号Password Char(10)NOT NULL密码PrivilegeCode Char(1)NOT NULL权限代码3.数据库脚本设计3.1 学院表 Depart 3.1.1 结构设计CREATE TABLE Depart(DepartNo Char(3)NOT NULL,/*学院编号*/DepartName Varchar2(30)NULL,/*学院名称*/Manager Varchar2(20)NULL,/*院长*/Telephone Varchar2(20)NULL,/*办公室电话*/constraint Depart_PK primary key(DepartNo);3.1.2 数据分布3.1.3 规则与约束学院编号的组成为:字符。3.1.4 索引3.1.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅不可以。3.1.6 说明3.2班级表 Class3.2.1 结构设计CREATE TABLE Class(ClassNo Varchar2(8)NOT NULL,/*班级编号*/ClassName Varchar2(30)NULL,/*班级名称*/TeacherNo Varchar2(9)NULL,/*班主任编号*/名师资料总结-精品资料欢迎下载-名师精心整理-第 5 页,共 12 页 -MonitorNo Char(9)NULL,/*班长编号*/DepartNo Char(3)NOT NULL,/*学院编号*/constraint Class_PK primary key(ClassNo),constraint Class_FK1 foreign key(DepartNo)references Depart(DepartNo),constraint Class_FK2 foreign key(TeacherNo)references Teacher(TeacherNo);3.2.2 数据分布3.2.3 规则与约束课程编号必须用外键(学院编号,班主任编号)关联。3.2.4 索引3.2.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅可以查询。3.2.6 说明3.3学生表 Student3.2.1 结构设计CREATE TABLE Student(StudentNo Varchar2(9)NOT NULL,/*学号*/StudentName Varchar2(20)NOT NULL,/*学生姓名*/Sex Varchar2(2)check(sex in(男,女)NULL,/*性别*/DepartNo Char(3)NOT NULL,/*学院编号*/ClassNo Varchar2(8)NOT NULL,/*班级编号*/BirthdayDate date NULL,/*出生日期*/FamilyAddress Varchar2(30)NULL,/*家庭地址*/QQ Varchar2(20)NULL,/*QQ 号码*/Telephone Varchar2(20)NULL,/*移动电话*/StudentImage blob NULL,/*相片*/StudentMemo varchar2(1000)NULL,/*备注*/constraint Student_PK primary key(StudentNo),constraint Student_FK1 foreign key(ClassNo)references Class(ClassNo),constraint Student_FK2 foreign key(DepartNo)references Depart(DepartNo);3.3.2 数据分布3.3.3 规则与约束学号必须用外键(班级编号,学院编号)关联。3.3.4 索引create index Student_IX on Student(StudentNo)pctfree 30 tablespace MyspaceIndex;3.3.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅可以查询。3.3.6 说明3.4 教师表 Teacher3.4.1 结构设计CREATE TABLE Teacher(TeacherNo Varchar2(9)NOT NULL,/*教师编号*/TeacherName Varchar2(20)NOT NULL,/*教师姓名*/Sex Varchar2(3)check(sex in(男,女)NULL,/*性别*/名师资料总结-精品资料欢迎下载-名师精心整理-第 6 页,共 12 页 -Position Varchar2(20)NULL,/*职称*/Telephone Varchar2(20)NULL,/*移动电话*/DepartNo Char(3)NOT NULL,/*学院编号*/TeacherMemo varchar2(1000)null,constraint Teacher_PK primary key(TeacherNo),constraint Teacher_FK1 foreign key(DepartNo)references Depart(DepartNo);3.4.2 数据分布3.4.3 规则与约束教师编号必须用外键(学院编号)关联。3.4.4 索引create index Teacher_IX on Teacher(TeacherNO)pctfree 30 tablespace MyspaceIndex;3.4.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅可以查询。3.4.6 说明3.5 课程表 Course 3.5.1 结构设计CREATE TABLE Course(Num number(3)NOT NULL,CourseNo Varchar2(6)NOT NULL,/*课程代码*/CourseName Varchar2(20)NOT NULL,/*课程名称*/Grades Varchar2(2)NULL,/*学分*/ClassLeaves Varchar2(4)NULL,/*班别*/SchoolHours Varchar2(6)NULL,/*上课时间*/TeacherNo Varchar2(9)NOT NULL,/*教师编号*/Capacity Varchar2(3)NULL,/*容量*/constraint Course_PK primary key(Num),constraint Course_FK1 foreign key(TeacherNo)references Teacher(TeacherNo);3.5.2 数据分布3.5.3 规则与约束3.5.4 索引3.5.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅可以查询。3.5.6 说明3.6学生选课表 Student_Coursing 3.6.1 结构设计CREATE TABLE Student_Coursing(StudentNo Varchar2(9)NOT NULL,/*学号*/CourseNo Varchar2(6)NOT NULL,/*课程代码*/CourseName Varchar2(20)NOT NULL,/*课程名称*/TeacherNo Varchar2(9)NOT NULL,/*教师编号*/constraint Student_Coursing_PK primary key(StudentNo),constraint Student_Coursing_FK1 foreign key(StudentNo)references Student(StudentNo),constraint Student_Coursing_FK3 foreign key(TeacherNo)references Teacher(TeacherNo);3.6.2 数据分布名师资料总结-精品资料欢迎下载-名师精心整理-第 7 页,共 12 页 -3.6.3 规则与约束3.6.4 索引3.6.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅可以查询。3.6.6 说明3.7 用户权限表 PrivilegeUsers3.7.1结构设计CREATE TABLE PrivilegeUsers(PrivilegeCode Char(2)NOT NULL,/*权限代码*/UserName Varchar2(80)NOT NULL,/*用户名称*/constraint Privilege_PK primary key(PrivilegeCode);3.7.2 数据分布3.7.3 规则与约束3.7.4 索引3.7.5 安全设计该表允许操作员和系统管理员可以修改,其他人员仅可以查询。3.7.6 说明3.8 教师登陆表 Teacher_Login 3.8.1结构设计CREATE TABLE Teacher_Login(TeacherNo Varchar2(9)NOT NULL,/*教师编号*/Password Varchar2(10)NOT NULL,/*密码*/PrivilegeCode Char(2)NOT NULL,/*权限代码*/constraint Teacher_Login_PK primary key(TeacherNo),constraint Teacher_Login_FK1 foreign key(TeacherNo)references Teacher(TeacherNo);3.9 超级管理员登陆表Super_Login 3.9.1结构设计CREATE TABLE Super_Login(SuperNo Varchar2(9)NOT NULL,/*管理员编号*/Password Varchar2(10)NOT NULL,/*密码*/PrivilegeCode Char(2)NOT NULL,/*权限代码*/constraint Super_Login_PK primary key(SuperNo);4.0 学生登陆表 Student_Login 4.0.1结构设计CREATE TABLE Student_Login(StudentNo Varchar2(9)NOT NULL,/*学号*/Password Varchar2(10)NOT NULL,/*密码*/PrivilegeCode Char(1)NOT NULL,/*权限代码*/constraint Student_Login_PK primary key(StudentNo),constraint Student_Login_FK1 foreign key(StudentNo)references Student(StudentNo);4.1 触发器设计4.1.1 功能:当插入教师编号时,编号必须满足为数字名师资料总结-精品资料欢迎下载-名师精心整理-第 8 页,共 12 页 -CREATE or REPLACE TRIGGER TeacherIns before insert ON Teacher FOR each row declare myError EXCEPTION;/*出错处理*/varLeft char(4);/*编号前 4 位*/varMid char(4);/*编号第 5 位*/varRight char(3);/*编号后 3 位*/i number;begin if LENGTH(:new.TeacherNo)!=8 then RAISE myError;end if;varLeft:=SUBSTR(:new.TeacherNo,1,4);varMid:=SUBSTR(:new.TeacherNo,5,1);varRight:=SUBSTR(:new.TeacherNo,6,3);if varMid!=-then RAISE myError;end if;for i in 1.4 loop if(SUBSTR(varLeft,i,1)9)then RAISE myError;exit;end if;end loop;for i in 1.3 loop if(SUBSTR(varRight,i,1)9)then RAISE myError;exit;end if;end loop;EXCEPTION WHEN myError THEN:new.TeacherNo:=NULL;end;4.1.2 功能:当修改教师编号时,编号必须满足为数字CREATE or REPLACE TRIGGER TeacherUpdate before update of TeacherNo ON Teacher FOR each row declare myError EXCEPTION;/*出错处理*/varLeft char(4);/*编号前 4 位*/varMid char(4);/*编号第 5 位*/varRight char(3);/*编号后 3 位*/i number;begin if LENGTH(:new.TeacherNo)!=8 then RAISE myError;end if;varLeft:=SUBSTR(:new.TeacherNo,1,4);varMid:=SUBSTR(:new.TeacherNo,5,1);名师资料总结-精品资料欢迎下载-名师精心整理-第 9 页,共 12 页 -varRight:=SUBSTR(:new.TeacherNo,6,3);if varMid!=-then RAISE myError;end if;for i in 1.4 loop if(SUBSTR(varLeft,i,1)9)then RAISE myError;exit;end if;end loop;for i in 1.3 loop if(SUBSTR(varRight,i,1)9)then RAISE myError;exit;end if;end loop;EXCEPTION WHEN myError THEN:new.TeacherNo:=:old.TeacherNo;:new.TeacherName:=:old.TeacherName;:new.sex:=:old.sex;:new.Position:=:old.Position;:new.Telephone:=:old.Telephone;:new.DepartNo:=:old.DepartNo;:new.TeacherMemo:=:old.TeacherMemo;end;4.1.3 产生教师编号函数,功能:根据输入的年份,自动产生教师编号CREATE or REPLACE FUNCTION funEmployeeNo(sYear varchar2)return varchar2 is x number;/*得到员工编号后三位的流水号*/varEmployeeNo1 varchar2(8);/*某年份的最大员工编号*/varEmployeeNo2 varchar2(8);/*新的员工编号*/begin varEmployeeNo1:=;select NVL(max(EmployeeNo),0)into varEmployeeNo1 from Employee where EmployeeNo like sYear|%;if varEmployeeNo1=0 then/*无该年份的员工,编号从001 开始*/varEmployeeNo2:=sYear|-001;else x:=to_number(SUBSTR(varEmployeeNo1,6,3)+1;if x 10 then varEmployeeNo2:=sYear|-00|ltrim(to_char(x);elsif x100 then varEmployeeNo2:=sYear|-0|ltrim(to_char(x);else varEmployeeNo2:=sYear|-|ltrim(to_char(x);end if;end if;return(varEmployeeNo2);end funEmployeeNo;4.1.4 产生教师编号过程,功能:根据输入的年份,自动产生教师编号CREATE or REPLACE PROCEDURE proEmployeeNo(sYear varchar2,returnEmployeeNo OUT varchar2)名师资料总结-精品资料欢迎下载-名师精心整理-第 10 页,共 12 页 -is x number;/*得到教师编号后三位的流水号*/varEmployeeNo1 varchar2(8);/*某年份的最大教师编号*/varEmployeeNo2 varchar2(8);/*新的教师编号*/begin varEmployeeNo1:=;select NVL(max(EmployeeNo),0)into varEmployeeNo1 from Employee where EmployeeNo like sYear|%;if varEmployeeNo1=0 then/*无该年份的教师,编号从001 开始*/varEmployeeNo2:=sYear|-001;else x:=to_number(SUBSTR(varEmployeeNo1,6,3)+1;if x 10 then varEmployeeNo2:=sYear|-00|ltrim(to_char(x);elsif x0 THEN raise_application_error(-20566,上课时间冲突!);END IF;END tri_CoursingTime;名师资料总结-精品资料欢迎下载-名师精心整理-第 11 页,共 12 页 -4.1.8创建触发器解决学生选课时间冲突CREATE OR REPLACE TRIGGER tri_StudentCoursing_Coursetime before INSERT OR UPDA TE ON Student_Coursing FOR each row DECLARE v_n int;BEGIN SELECT COUNT(*)INTO v_n FROM Student_Course WHERE studentID=:new.studentID and SchoolHours=:new.SchoolHours;IF v_n0 THEN raise_application_error(-20588,时间冲突!);END IF;END;5.创建表空间5.1 创建表空间MyspaceIndex,用以存放索引的基本信息create tablespace MyspaceIndex datafile f:xxglMyspaceIndexsize 10M default storage(initial 50k next 50k minextents 2 maxextents 50 pctincrease 0);6.创建表索引6.1 创建学生表索引create index Student_IX on Student(StudentNo)pctfree 30 tablespace MyspaceIndex;6.2 创建教师表索引create index Teacher_IX on Teacher(TeacherNO)pctfree 30 tablespace MyspaceIndex;6.3 创建课程索引create index Course_IX on Course(Num)pctfree 30 tablespace MyspaceIndex;名师资料总结-精品资料欢迎下载-名师精心整理-第 12 页,共 12 页 -

    注意事项

    本文(2022年2022年教务管理信息系统的数据库设计实例 .pdf)为本站会员(C****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

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

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开