学生成绩管理系统课程设计说明书(共20页).doc

上传人:飞****2 文档编号:17086841 上传时间:2022-05-21 格式:DOC 页数:20 大小:1.47MB
返回 下载 相关 举报
学生成绩管理系统课程设计说明书(共20页).doc_第1页
第1页 / 共20页
学生成绩管理系统课程设计说明书(共20页).doc_第2页
第2页 / 共20页
点击查看更多>>
资源描述

《学生成绩管理系统课程设计说明书(共20页).doc》由会员分享,可在线阅读,更多相关《学生成绩管理系统课程设计说明书(共20页).doc(20页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上 长 春 大 学 课 程 设 计 说 明 书题目名称 学生成绩管理系统 院(系) 软件学院 班 级 软件工程09403 学生姓名 赵健 吕阳 谷雨卓 刘涛 指导教师 刘 艳 起止日期 2010.07.122010.07.16 目 录一、设计题目1二、设计目的1三、设计分析1四、概念结构设计2五、逻辑结构设计3六、数据库实现5七、结论17专心-专注-专业一、设计题目学生成绩管理系统二、设计目的运用已学过的知识进行一个简单的应用程序的开发。基本掌握设计课题的基本步骤和方法。掌握应用系统开发中的需求分析。基本掌握应用系统开发中设计文档的编制。三、设计分析因为我做的是学生成绩

2、管理,所以数据库中至少有个一个表是来存储学生的各科成绩的。有了学生成绩,得知道这个成绩是哪个学生的,所以此表中也得有学生姓名,但是学生姓名可能有重复的 ,所以得必须有个标志来惟一标识一个学生,所以得给每个学生一个编号(学号),但是也得必须清楚,这个成绩是哪门课程的,所以给课程定义了一个编号。之后,得想到有了学生成绩表,总得有个表来存放学生信息吧,所以又建立一个学生信息表,此表中的必须的字段得有学号、姓名、班级,其他的字段可以根据需要来添加。然后就是得有个课程表来存放哪个教师教哪门课程信息,所以此表中至少得有课程号,课程名称和教师的惟一标识(教师编号),再有一个表来存放教师的信息的,其中的字段必

3、须有教师编号,教师姓名和所在的部门,当然也可以有教师出生日期、职称、电话号码等字段。总之,这个学生管理系统总共包括四个表:学生信息表student、教师信息表teacher、成绩表score和课程表course。Student表:在建表时,除了添加学号、姓名、班级必要字段,还添加一些其他的字段,比如:出生日期、性别、邮箱地址和类型等。Teacher表:在建表时,除了添加教师编号,教师姓名,部门必要字段,还可以添加一些其他的字段,比如:出生日期、性别、和电话等。Score表:此表应该包括学生学号、课程号和成绩等。Course表:应包括课程号,对应的课程名称和教此课程的教师编号。(1)建立一个数据

4、库,然后在此数据库中建立这四个数据表。(2)向表中添加记录。(3)用一些查询语句来查看表中的特定记录。(4)向表中添加一些字段。如:向teacher表中添加字段 tel(5)创建一个自定义数据类型,并修改student表中的某个字段为此数据类型。(6)创建几个视图查询某个班级的学生信息查看每门课程的平均成绩查看选修计算机课程的学生信息查看所有男教师和所有男学生的信息(7)创建几个存储过程显示成绩表中的课程号在课程表中且所任教师性别为男、计算机系的成绩表。显示某学生的学号,姓名,所学课程号,课程名称和对应的成绩。在执行此存储过程时,如果没有给出参数(学生姓名),则输入全部的学生的学号,姓名,班级

5、,任课教师编号及其姓名,所学课程名称和成绩,如果有,则显示此学生的以上信息。(8)创建触发器在成绩表中建立一个触发器,当向表中添加记录时,此学生的成绩都乘以1.2。检查学生的邮箱地址是否相同,如果相同,输出inserting fail,并且回滚事务;如果不相同,则插入成功。在成绩表建立一个触发器,在向表中插入记录时,检验插入的课程号是否在课程表中的课程号的范围之内。(9)创建规则,并绑定在向成绩表中添加记录时,如果成绩degree(select degree from score where sno=101 and cno=02)如图5所示。图5查询记录(2)查询课程号01大于课程号02的最大

6、值、并以分数降序排序的成绩表中所有列select * from score s where o=01 and s.degree=(select max(degree) from score y where o=02 ) order by degree descgo select max(degree) as 02max from score where cno=02如图6所示。 图6查询记录(3)查询性别为男的学号,姓名,班级,课程号和成绩的学生select student.sno,student.sname,student.class,o,score.degree from student,

7、score where student.sno=score.sno and ssex=男如图7所示。图7查询记录(4)查询成绩在60到80之间的所有列select * from score where degree between 60 and 80如图8所示。图8查询记录(5)查询score表中至少有5名学生选修的并以0开头的课程的平均分select avg(degree) as 平均分,cno from score where cno like 0% group by cno having count(*)=5如图9所示。图9查询记录6、创建自定义数据类型创建一个email自定义数据类型e

8、xec sp_addtype email, varchar(20) , null修改student表中的semail数据类型为email类型alter table student alter column semail email7、向表中添加字段向student表添加type,semail,b并且邮件地址有check约束alter table student add type char(7)alter table student add semail varchar(20) null constraint ck_sem check (semail like %) alter table te

9、acher add tel varchar(15)8、创建视图(1)创建所有11班的学生信息的视图create view student11as select * from student where class=11查看视图中的记录select * from student11如图10所示。图10查看视图(2)创建视图course_degree,其中的内容是选修计算机课程的学生信息,包括(sno,sname,cno,cname,degree),创建时加上with check optioncreate view course_degree(sno,sname,cno,cname,degree)

10、as select score.sno,sname,o,cname,degree from course ,student, score where o=o and student.sno=score.sno and cname=计算机with check option查看视图中的记录select * from course_degree如图11所示。图11查看视图(3)创建一个视图,其中的内容是成绩表中每门课程的create view averageas select avg(degree) as 平均分 from score group by cno查看视图中的记录select * fro

11、m average 如图12所示。图12查看视图(4)创建视图其中的内容是所有男教师和男学生的name,sex,birthcreate view manasselect sname as name,ssex as sex,sbirth as birth from student where ssex=男union select tname,tsex,tbirth from teacher where tsex=男查看视图中的记录select * from man如图13所示。图13查看视图9、创建规则规则的作用月CHECK约束的部分功能相同,在向表中的某列插入或更新数据时,用它来限制输入的新值

12、的取值范围。而它与CHECK约束不同的是:l CHECK约束是用CREATE TABLE语句在建表时指定的,而规则需要作为单独的数据库对象来实现。l 在一个列上只能使用一个规则。但可以使用多个CHECK约束。l 规则可以应用于多个列,还可以应用于用户自定义的数据类型,而CHECK约束只能应用于它定义的列。(1)创建一个degree_rule规则create rule degree_rule asvalues0把此规则绑定到score表中degree列exec sp_bindrule degree_rule,score.degree在向成绩表中添加记录时,如果成绩degree0,则插入不成功。(

13、2) 创建一个tel_rule规则create rule tel_rule as value like 0-9 0-9 0-9 0-9 0-9 0-9 0-9 0-9把此规则绑定到teacher表中tel列exec sp_bindrule tel_rule,teacher.tel在向教师表中添加记录时,如果电话号码不是0-9的数字,则插入不成功。10、创建存储过程存储过程是存储在服务器上的例行程序及过程,在SQL SERVER只能感定义某个过程,其中记录了一系列的造作,每次应用程序只需调用该过程就可完成该操作,这种SQL SERVER中定义的过程就被称为存储过程。它可以完成以下功能:l 接受输

14、入参数并返回多个输出值。l 包含T-SQL语句用以完成特定的SQL SERVER操作,其中可以有对其他存储过程的调用。l P返回一个指示成功与否及失败原因的状态代码给调用它的过程。存储过程不能接用过程名返回值,也不能直接在表达式中使用。(1)创建一个存储过程,来显示成绩表中的课程号在课程表中并且所任教师性别为男、所在部门是计算机系的成绩表中的列create proc student_11as select * from score where cno in (select cno from course ,teacher where course.tno=teacher.tno and dep

15、art=计算机系 and tsex=男)调用此存储过程Execel student_11如图14所示。图14调用存储过程(2)创建一个带输入参数的存储过程,调用此存储过程时,给出一个学生名,显示出此学生的学号,姓名,所学课程号,课程名称和对应的成绩create proc student_namesname varchar(10)as select student.sno,sname,o,degree cname from student,score,course where student.sno=score.sno and o=o and sname=sname调用此存储过程,(此例是输出姓

16、名为历史的学生的信息)exec student_name 历史如图15所示。图15调用存储过程(3)创建一个存储过程,在执行此存储过程时,如果没有给出参数(学生姓名),则输入全部的学生的学号,姓名,班级,任课教师编号及其姓名,所学课程名称和成绩,如果有,则显示此学生的以上信息。create proc student_teachersname varchar(10)=nullasif sname is nullselect student.sno,sname,student.class,teacher.tno,teacher.tname,degree,cname from student,sco

17、re,course,teacherwhere student.sno=score.sno and o=o and course.tno=teacher.tnoelseselect student.sno,sname,student.class,teacher.tno,teacher.tname,degree,cname from student,score,course,teacherwhere student.sno=score.sno and o=o and course.tno=teacher.tno and sname=sname调用此存储过程 exec student_teacher

18、(没有实参)如图16所示 。图16调用存储过程exec student_teacher 历史 (查询姓名为历史的学生的选课信息和成绩)如图17所示。图17调用存储过程(4)创建一个存储过程,传递一个学生姓名,先判断此学生是否有邮箱,如果有,则显示此学生的姓名,邮箱地址,学号,班级;如果没有的话,输出此句话the semail is emptycreate proc student_emailsname varchar(10)asbeginif (select semail from student where sname=sname) is nullbeginprintthe semail i

19、s emptyendelseselect sname,semail,sno,class from student where sname=snameend调用此存储过程 exec student_email super如图18所示。图18调用存储过程当给出姓名的那个学生没有邮箱地址时,则会显示如下内容。 exec student_email dfdf如图19所示。图19调用存储过程11、触发器触发器是一种特殊的存储过程,它不能显式地调用,而是在往表中插入记录、更新记录或者删除记录时,被自动的激活。所以,触发器可以用来对表实施复杂的完整性约束,当触发器所保护的数据发生改变时,触发器会自动被激活,

20、从而防止对数据的不正确修改。在触发器中卡仪查询其他表,也可以执行更复杂的T-SQL语句。如果发现引起触发器执行的T-SQL语句执行了一个非法的操作,则可以通过回滚事务使语句不能执行,回滚后SQL SERVER会自动返回到此事务执行前的状态。SQL SERVER为每个触发器都查了两个专用表,inserted表和deleted表.这两个表的结构总是与被该触发器作用的表的结构相同。触发器执行完成后,与该触发器相关的这两个表也会被删除。一个表中可以有多个具有不同名称的各种类型的触发器,每个触发器都可以完成不同的功能,但每个触发器只能作用在一个表上。(1)创建一个触发器,来检查学生的邮箱地址是否相同,如

21、果相同,输出inserting fail,并且回滚事务;如果不相同,则插入成功。create trigger studentinserton studentafter insertas if (select semail from inserted where semail in (select semail from student) is not nullbeginprint inserting failrollback transactionendelseprintinsering succeed向学生信息表中插入一条记录,检验是否成功插入insert into student valu

22、es(114,lengbing,女,1985-12-12,11,lengbingssh,一般)(2)在成绩表中建立一个触发器,当向表中添加记录时,此学生的成绩都乘以1.2create trigger scoreupdate on scoreafter insertas update score set degree=degree*1.2 from score where sno in (select sno from inserted )向表中插入一条记录,检验触发器是否有用。insert into score values(108,01,56)(3)在成绩表建立一个触发器,在向表中插入记录时

23、,检验插入的课程号是否在课程表中的课程号的范围之内。如果在,则插入成功;否则,提示信息没有这门课程,回滚事务。create trigger course_scoreon scoreafter insertas if (select cno from inserted where cno in(select cno from course) is nullbegin print没有这门课程rollback transactionend向表中添加一条记录,进行验证。insert into score values(108,06,60)12、自定义函数函数是由一条或多条T-SQL语句组成的代码段,用

24、语实现一些常用的功能,编写好的函数可以重复使用。用户自定义函数可以接受零个或多个输入参数,函数的返回值可以是一个数值,也可以是一个表。用户自定义函数有三种类型:1、 返回数值的用户自定义函数2、 内联(单语句)的返回表的用户自定义函数3、 多语句的返回表的用户自定义函数(1)创建一个用户自定义函数,输出与指定的学生同班的学生个数create function studentcount(sno char(5)returns intbegineclare counter intselect counter=count(*) from student where class=(select clas

25、s from student where sno=sno)return counterend调用此自定义函数(本例是查找与学号102同班的学生个数)declare a intset a=dbo.studentcount(102)print convert(char(3),a)(2)创建一个用户自定义函数,用于输出同一个班级中的学生信息create function studentclass(class char(5)returns tablereturn(select * from student where class=class)调用自定义函数(本例是输出12班的学生信息)select *

26、 from studentclass(12)(3)创建一个自定义函数,把某一学生所学课程名称,课程号及其成绩插入一个临时表中显示出来。create function studentscore(sno varchar(5)returns student_score table(sno char(5), sname varchar(10), cno char(5), cname varchar(10), degree float)begin insert student_scoreselect student.sno,sname,o,cname,degree from student,score,

27、coursewhere student.sno=score.sno and o=o and student.sno=sno returnend查看学号为103的学生的各科成绩。select * from studentscore(103)13、建立索引SQL SERVER的索引是一种物理结构,它能够提供一种以一列或多列的值为基础迅速查找表中行的能力。索引中记录了表中的关键值,提供了指向表中行的指针。它既可以在定义表时创建,也可以在定义表之后的任何时候创建。索引可以创建在一个列或多个列的组合上。(1)在学生信息表邮箱列上创建一个惟一性的非聚簇索引create unique nonclustere

28、d index ix_semail on student(semail)(2)在学生信息表的学号列上创建一个惟一性聚簇索引create unique clustered index ix_sno on student (sno desc)(3)在教师信息表的姓名列上创建一个非惟一性的非聚簇索引create nonclustered index ix_name on teacher(tname)七、结论总的来说,是把以前老师讲的知识又串了一下,又熟悉了许多,很多以前没有弄明白的知识点,通过这次课程设计,差不多都掌握了,对于那些像触发器、存储过程、自定义函数、视图等等应用程序的建立、使用方法和作用

29、,我又有了更深一步的了解和掌握。但是还有很多欠缺,就像我做这些东西,感觉没有一定的逻辑顺序,好象之间没有多大的联系似的,所以还要更进一步的完善,但是由于时间紧迫,没有办法完善它。做此课程设计过程中,得到老师和同学的大力支持和帮助,在此特别感谢。在这次课程设计的过程中,我们体会到要想开发一个系统软件,不仅需要相当的专业技术知识,还要有严谨缜密的思维能力。只有思想上清晰了,编程才有意义,否则就是白费力气。同时还要善于捕获细小的方面,因为那往往是这个程序的致命因素。这次毕业设计培养了我的细心和耐性,更树立了一种科学的态度。这对我以后的工作和学习也有很大的帮助和指导作用。同时也深刻认识到了本身不存在很多不足之处,还需要不断地学习来充实完善自己,只有这样才能学有所成,求得更大的发展。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

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

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