《大工秋SQL数据库课程设计答案.docx》由会员分享,可在线阅读,更多相关《大工秋SQL数据库课程设计答案.docx(20页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、 网络教化学院SQL数据库课程设计题 目:学生信息管理系统的设计与实现学习中心: 奥鹏学习中心 专 业: 年 级: 年 /秋 季 学 号: 学 生: 指导老师: 龙 珠 第 18 页1 工程概况1.1 SQL 数据库简介Microsoft SQL Server 2000 是Microsoft 公司继SQL Server 6.5与SQL Server 7.0以后,在新千年推出的又一改良的新版关系型数据管理系统。它能运用户快捷地管理数据库与开发应用程序。SQL Server 2000 运用了了先进的数据库构造,与Windows DNA严密集成,具有强大的Web 功能,它可以利用高端硬件平台以与最新
2、网络与存储技术,可以为最大的Web站点与企业应用供应优良的扩展性与牢靠性,运用户可以在Internet 领域快速建立效劳系统,为占据市场赢得珍贵的时间。同时,SQL Server 2000 还为用户供应了重要的平安性功能的增加,为用户的数据平安供应了牢靠的保证。另外,SQL Server 2000还为用户供应了重要的平安性功能的增加,为用户的数据平安供应了牢靠的保证。另外,SQL Server 2000 在数据库效劳器自动管理技术方面处于数据库领域的领先地位,它可以运用户免去繁琐困难的工作量,从而有精力处理更重要的问题,运用系统在商业战略上占得先机。SQL Server 2000 的特性Mic
3、rosoft® SQL Server 2000 的特性包括:1、Internet 集成。SQL Server 2000 数据库引擎供应完好的XML 支持。它还具有构成最大的Web 站点的数据存储组件所需的可用性、可伸缩性与平安功能。2、可伸缩性与可用性。同一个数据库引擎可以在不同的平台上运用,从运行 Microsoft Windows® 98 的便携式电脑到运行 Microsoft Windows 2000 数据中心版的大型多处理器效劳器。3、业级数据库功能。SQL Server 2000 关系数据库引擎支持当今苛刻的数据处理环境所需的功能。数据库引擎充分疼惜数据完好性,同时将管
4、理上千个并发修改数据库的用户的开销减到最小。4、易于安装、部署与运用。 SQL Server 2000 中包括一系列管理与开发工具,这些工具可改良在多个站点上安装、部署、管理与运用 SQL Server 的过程。1.2 JSP概述JSP(JavaServer Pages)是由Sun Microsystems公司提倡、很多公司参与一起建立的一种动态网页技术标准。JSP技术有点类似ASP技术,它是在传统的网页HTML文件(*.htm,*.html)中插入Java程序段(Scriptlet)与JSP标记(tag),从而形成JSP文件(*.jsp)。 用JSP开发的Web应用是跨平台的,即能在Linu
5、x下运行,也能在其他操作系统上运行。JSP技术运用Java编程语言编写类XML的tags与scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags与scriptlets访问存在于效劳端的资源的应用逻辑。JSP将网页逻辑与网页设计与显示分别,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得快速与简洁。 Web效劳器在遇到访问JSP网页的恳求时,首先执行其中的程序段,然后将执行结果连同JSP文件中的HTML代码一起返回给客户。插入的Java程序段可以操作数据库、重新定向网页等,以实现建立动态网页所须要的功能。 JSP与Java Servlet一样,是在效劳器端执行的,通
6、常返回该客户端的就是一个HTML文本,因此客户端只要有阅读器就能阅读。 JSP页面由HTML代码与嵌入其中的Java代码所组成。效劳器在页面被客户端恳求以后对这些Java代码进展处理,然后将生成的HTML页面返回给客户端的阅读器。Java Servlet 是JSP的技术根底,而且大型的Web应用程序的开发须要Java Servlet与JSP协作才能完成。JSP具备了Java技术的简洁易用,完全的面对对象,具有平台无关性且平安牢靠,主要面对因特网的全部特点。1.3 系统开发背景随着学校规模的不断扩大,学生人数急剧增长,须要管理的各种信息也成倍增长,由于计算机与网络的普与,若建立一个C/S或B/S
7、构造的学生信息管理系统,学生便可以通过网络来选课并且查询自己的有关信息,使得学生信息管理工作系统化,标准化,自动化,大大进步了学校管理学生的效率。在信息高速开展的当今时代,任何学校,企业都离不开信息化的建立,信息化程度已经成为一个评价高校综合实力的一项重要指标。近年来,高校都建立了高校校园网,学生信息管理系统作为高校校园网建立的一个模块,主要是为了学生在校园网内就理解更多的与学生生活相关的信息。学校的公告网上发布,学生信息网上查询,便利老师与学生查询学生信息,成果查询使学生能与时理解自己的成果以与便利学生选课,同时也便利老师与时做出课程的调整等。学生信息管理系统可作为一个高校学生获得信息,学生
8、沟通,选课与教务管理的平台。1.4 学生信息管理系统概述学生信息管理系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、标准化与自动化,其主要任务是用计算机对学生各种信息进展日常管理,如查询、修改 、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统;本系统主要用于学校学生信息管理,总体任务是实现学生信息关系的系统化、标准化与自动化,其主要任务是用计算机对学生各种信息进展日常管理,如查询、修改 、增加、删除,另外还考虑到学生选课,针对这些要求设计了学生信息管理系统。本系统主要包括学生信息查询、教务信息维护与学生选课三局部。其功能主要有:1、有关学籍等信息的输入,
9、包括输入学生根本信息、所在班级、所学课程与成果等。2、学生信息的查询,包括查询学生根本信息、所在班级、已学课程与成果等。3、学生信息的修改。4、班级管理信息的输入,包括输入班级设置、年级信息等。5、班级管理信息的查询。6、班级管理信息的修改。7、学生课程的设置与修改。2 需求分析2.1 需求分析经过细致探讨分析,我们确定将系统分为四大菜单局部,分别为新生根本信息管理,在校日常管理,毕业生信息管理,学生成果查询四局部。为了便于导员与学校指导对班级状况的理解管理,其中主要侧重点在在校日常管理方面。 新生信息:包括报到预处理,新生报到,新生信息查询与统计 在校生信息管理:包括根本数据、日常管理,奖惩
10、信息,勤工助学 毕业生信息:包括择业与就业、档案与经费、证书发放 学生成果查询:包括成果的查询在系统需求的分析过程中我们承受的是跟班作业的调查方法。通过为期两天的亲身参与学校的业务工作根本理解了用户的需求。主要包括入学报道管理学生信息,在校生日常管理,毕业生信息管理,学生成果综合查询与统计。2.2 可行性分析整个系统应当操作简便,界面友好,维护简便。数据库要求运行稳定,执行速度快,数据平安性高。软件系统本身运行对计算机硬件平台与操作系统平台要求适中。该工程承受JSP编写,数据库承受SQL Server,开发者对其都可以较为娴熟的应用,再加上老师的指导,因此在技术上也是可行的。运行可行性分析:本
11、系统运行平台是JSP 且 有SQL SERVER,阅读器web2.0以上就能运行,操作系统Windows XP以上。所以本系统在运行上要求适中,相宜学校以与一些公司管理学生或员工信息时运用操作可行性分析:高校教职工与高校生都具备良好的计算机根本操作学问,因此该学生管理系统很简洁被用户承受,用户可以很快地熟识该系统的操作方式。 经济可行性分析:本钱效益分析是通过比拟工程的全部本钱与效益来评估工程价值的一种方法,本钱效益分析作为一种经济决策方法对预开发施行的工程具有重要的指导作用。学生管理系统的投入,可以进步教职工的工作效率,削减工作人员,从而削减人力资本的投入,依据核算,系统投入后不久,就可以根
12、本收回开发系统的投资,从经济角度来说,2.3 数据分析1、学生表构造:表1编号字段名称字段类型字段宽度1学号CHAR152姓名CHAR103性别CHAR24诞生日期DATE85 CHAR106家庭住址CHAR507班级CHAR208原毕业学校CHAR509是否住宿CHAR410政治相貌CHAR611入学总分LONG412专业char202、课程表构造: 表2编号字段名称字段类型字段宽度1课程名称CHAR152年级CHAR103专业char203、成果表构造:表3编号字段名称字段类型字段宽度1学号CHAR152课程名称CHAR153期中成果LONG44期末成果LONG45总评成果LONG46班级
13、char204、总分表构造:表4编号字段名称字段类型字段宽度1学号CHAR152期中总分LONG43期末总分LONG44期中名次LONG45期末名次LONG46班级char202.4 功能分析本系统的主要任务是实现对学校教化处的学生信息管理、成果管理、课程管理与相关查询。其主要功能包括:1、学生信息管理功能班级管理。供应应班主任进展本班学生的信息更新、删除。添加学生。以班级为单位,进展学生入库。其中分为单个添加与成批添加。单个添加学生供数量较少的学生信息入库;成批添加可以从现存的学生信息EXCEL文件中成批录入到数据库中。删除学生。当学生毕业后,学生信息转移备份数据库中,系统的根本数据库中须要
14、删除学生信息。该功能主要进展成批地删除学生信息,如连续学号区段的多位学生信息删除,整个班级的删除,全部学生信息的删除。新生管理。本局部的功能主要有新生导入、分班、与设置学号。新生导入实现从现存的EXCEL新生名单中录入学生信息。分班功能实现按新生的报考专业、成果与性别进展分班。设置学号实现自动为各班学生编发学号。学生信息备份。在学生信息删除前,将其按班级为单位保存到备份数据库。2学生成果管理功能分数录入。以班级为单位,录入各科目的期中、期末、总评成果。总分与名次。计算指定班级学生的总分与名次。补考成果录入。修改总评成果,以确定最终补考人数。成果备份。为指定班级与指定的学期数的学生成果保存到备份
15、数据库中。3、课程信息管理功能课程管理。供应本学期各年级各专业所开课程名称的录入、修改、删除。它是学生成果管理的根底。用以保证数据库中一样性原则。4、查询功能。学生信息查询。依据用户的要求,查询学生数据库的全部可能的信息,其中包括成果查询。备份成果查询。按班级为单位查询备份数据库的学生信息,补考状况。3 具体设计3.1 系统构造图系统功能模块示意图如图3.1所示。图3.1 系统功能构造图3.2 系统实现(1)注册界面为了便利管理,不同的管理员可以注册不同的用户名与密码来进入管理员系统功能,注册信息将提交到数据库中。注册页面是为了保证规定权限的管理员才能对学生信息进展修改、删除、添加等功能。注册
16、界面如下:假设新注册的用户名已经存在数据库中,则系统会出现提示信息“该用户名已经存在”。注册胜利时,系统同样会提示注册胜利,并将新注册的信息提交到数据库中,用户就可以通过新的用户名与密码进入到管理员登录界面。(2)、登录界面对于已经注册的管理员,在进入管理系统之前先要进展登录,在下面的登录界面经过身份验证后才能进入系统管理界面。只有有正确用户名与密码的管理员才能进入管理员界面,对数据库中的学生信息进展添加、修改与删除等功能。输入的用户名与密码首先与数据库中的数据进展比拟,存在的用户可以干脆进入管理员界面完成管理员功能,假设信息错误系统将会提示用户名或密码输入错误并返回。2)、增加学生根本信息数
17、据通过管理员身份验证后,管理员进入的就是学生信息增加的页面,在该页面中输入要增加的学生相关信息并提交,写入到aa学生信息表中。同时这个界面还包括管理员可以运用的其它功能,如信息的查询、修改与删除等功能。其工作界面如下:3)、查询数据查询数据,该局部是通过用户输入的欲查询的学生学号来查询该学生的具体信息。用户输入学号后假设数据库中不存在该学号的学生,系统将会提示该学生不存在信息。假设存在该学生系统将会输出该学生的具体信息,包括学生姓名、学号、性别、照片,学生具体信息显示如下:3.3 数据库实现(1)数据更新CREATE TRIGGER scupdate ON dbo.student /建立学生信
18、息表更新触发器FOR UPDATE ASUPDATE SC /更新学生选课表SCSET SNO = (SELECT SNO FROM INSERTED) /将SC表中的学号改成学生表改后的WHERE SNO = (SELECT SNO FROM DELETED); /更改对应的学生学号CREATE TRIGGER graduateupdate ON dbo.student /建立学生信息表更新触发器FOR UPDATE ASUPDATE GRADUATE /更新学生毕业信息表GRADUATESET SNO = (SELECT SNO FROM INSERTED) /将GRADUATE表中的学号
19、改成学生表修改后的WHERE SNO = (SELECT SNO FROM DELETED); /更改对应的学生学号CREATE TRIGGER majorupdate ON dbo.student /建立学生信息表更新触发器FOR UPDATE ASUPDATE MAJOR /更新专业信息表MAJORSET SNO = (SELECT SNO FROM INSERTED) /将MAJOR表中的学号改成学生表修改后的WHERE SNO = (SELECT SNO FROM DELETED); /更改对应的学生学号CREATE TRIGGER student1 ON dbo.major /建立专
20、业信息表更新触发器FOR UPDATE ASUPDATE STUDENT /更新学生信息信息表STUDENTSET MNO = (SELECT MNO FROM INSERTED) /将STUDENT表中的专业号改成专业表修改后的WHERE MNO = (SELECT MNO FROM DELETED); /更改对应的专业号CREATE TRIGGER student2update ON dbo.department /建立院系信息表更新触发器FOR UPDATE ASUPDATE STUDENT /更新学生信息信息表STUDENTSET DMPNO = (SELECT DMPNO FROM
21、INSERTED) /将STUDENT表中的院系号改成专业表修改后的WHERE DMPNO = (SELECT DMPNO FROM DELETED); /更改对应的院系号(2) 数据删除CREATE TRIGGER teach1update ON dbo.teacher /建立老师信息表删除触发器FOR DELETE ASUPDATE TEACH /删除授课信息表TEACHSET TNO = NULL /删除TEACH表中的教工号删除WHERE TNO = (SELECT TNO FROM DELETED) /找到对应的教工号CREATE TRIGGER sc1update ON dbo.c
22、ourse /建立课程信息表删除触发器FOR DELETEASUPDATE SC /删除选课信息表SCSET CNO = NULL /删除SC表中的课程号删除WHERE CNO = (SELECT CNO FROM DELETED) /找到对应的课程号CREATE TRIGGER stu_majorupdate ON dbo.major /建立专业信息表删除触发器FOR DELETE ASUPDATE STUDENT /删除学生信息表STUDENT SET MNO = NULL /删除STUDENT 表中的专业号删除WHERE MNO = (SELECT MNO FROM DELETED) /
23、找到对应的专业号CREATE TRIGGER teacherupdate ON dbo.department /建立院系信息表删除触发器FOR DELETE ASUPDATE TEACHER /删除老师信息表TEACHER SET DMPNO = NULL /删除TEACHER表中的院系号删除WHERE DMPNO = (SELECT DMPNO FROM DELETED) /找到对应的院系号2.2 存储过程存储过程是PL/SQL语句书写的过程,这个过程经编译与优化后存储在数据库效劳器中,运用时只要调用即可。(1)数据查询存储过程名:老师信息查询入口参数:tno varchar(10)/输入老
24、师的教工号出口参数:tno char(10), tname varchar(10), profess varchar(10), dname varchar(10), tel int, tsex char(2),/定义存放输出老师信息的变量CREATE PROCEDURE selectteacher /建立查询老师信息存储过程tnoASSELECT tno = tno FROM INSERTED /选择与输入教工号相等的全部记录SELECT * /选出符合条件的老师全部信息 FROM teacher GO存储过程名:院系信息查询入口参数:dmpno/输入院系的院系号出口参数:dmpno, dmp
25、name,dmphead, /定义存放输出院系信息的变量CREATE PROCEDURE selectdepartment/建立查询院系信息存储过程dmpnoASSELECT dmpno = dmpno FROM INSERTED/选择与输入院系号相等的全部记录SELECT */选出符合条件的院系全部信息 FROM department GO(2)数据插入存储过程名:学生信息插入入口参数:sno varchar(10), id varchar(20), intime varchar(20),birthplace varchar(10), sname varchar(10),ssex char(
26、2), birthday varchar(20),symbol varchar(8), homeaddr varchar(20), postcode int,/输入须要插入的学生全部信息 出口参数: 无CREATE PROCEDURE insertstudent/建立插入学生信息的存储过程 sno varchar(10), id varchar(20),intime varchar(20),birthplace varchar(10), sname varchar(10),ssex char(2), birthday varchar(20),symbol varchar(8),homeaddr
27、 varchar(20), postcode int,/定义存放插入学生信息的变量ASINSERT INTO student(sno,sname,ssex,birthday,symbol,id,intime,birthplace,homeaddr,postcode)/插入学生表对应的列名VALUES (sno varchar(10), sname varchar(10), ssex char(2),birthday varchar(20), symbol varchar(8), id varchar(20),intime varchar(20), birthplace varchar(10),
28、homeaddr varchar(20), postcode int)/插入学生表对应列名值GO存储过程名:老师信息插入入口参数:tno char(10), tname varchar(10), profess varchar(10), dname varchar(10), tel int, tsex char(2), /输入须要插入的老师全部信息 出口参数: 无CREATE PROCEDURE insertteacher tno char(10), tname varchar(10),profess varchar(10),dname varchar(10), tel int,tsex ch
29、ar(2),/定义存放输出老师信息的变量ASINSERT INTO teacher(tno,tname,tsex,profess,dname,tel)/插入老师表对应的列名VALUES (tno char(10), tname varchar(10), tsex char(2),profess varchar(10), dname varchar(10), tel int,)/插入老师表对应列名值GO(3)数据删除存储过程名:学生信息删除入口参数:sno varchar(10) /输入要删除学生的学号 出口参数: 无CREATE PROCEDURE deletestudent /建立删除学生信
30、息的存储过程sno,ASSELECT sno = sno FROM DELETED /选择与输入学号相等的全部记录DELETE FROM student/删除符合条件的记录GO存储过程名:专业信息删除入口参数:mno varchar(10) /输入要删除专业的专业号 出口参数: 无CREATE PROCEDURE deletemajor/建立删除专业信息的存储过程 mname,ASSELECT mname = mname FROM DELETED/选择与输入专业号相等的全部记录DELETE FROM major/删除符合条件的记录GO(4)数据更新存储过程名:学生学号更新入口参数: no in
31、t, /输入要更新的学生学号 出口参数: sno int,/输出更新后的学生学号CREATE PROCEDURE updatesno /建立更新学生学号的存储过程 no int,ASSELECT no = sno FROM INSERTED/选择与输入学号相等的全部记录UPDATE studentSET sno=no/更新符合条件的记录GO存储过程名:专业名更新入口参数:mname varchar(20),/输入要更新的专业名称 出口参数:name varchar(20),/输出更新后的专业名称CREATE PROCEDURE updatemname /建立更新专业名的存储过程 name varchar(20),ASSELECT mname = mname FROM INSERTED/选择与输入学号相等的全部记录UPDATE majorSET mname=name/更新符合条件的记录GO心得与体会SQL数据库课程设计是大连理工高校网络教化学院计算机应用技术专业开展的一项理论教学环节,是理论联络理论的纽带与桥梁,自己通过学习这个课程培育了我们综合运用所学学问解决实际问题的有效手段。