1、(1)建立一个数据库,然后在此数据库中建立这四个数据表。(2)向表中添加记录。(3)用一些查询语句来查看表中的特定记录。(4)向表中添加一些字段。如:向teacher表中添加字段 tel(5)创建一个自定义数据类型,并修改student表中的某个字段为此数据类型。(6)创建几个视图查询某个班级的学生信息查看每门课程的平均成绩查看选修计算机课程的学生信息查看所有男教师和所有男学生的信息(7)创建几个存储过程显示成绩表中的课程号在课程表中且所任教师性别为男、计算机系的成绩表。显示某学生的学号,姓名,所学课程号,课程名称和对应的成绩。在执行此存储过程时,如果没有给出参数(学生姓名),则输入全部的学生
2、的学号,姓名,班级,任课教师编号及其姓名,所学课程名称和成绩,如果有,则显示此学生的以上信息。(8)创建触发器在成绩表中建立一个触发器,当向表中添加记录时,此学生的成绩都乘以1.2。检查学生的邮箱地址是否相同,如果相同,输出inserting fail,并且回滚事务;如果不相同,则插入成功。在成绩表建立一个触发器,在向表中插入记录时,检验插入的课程号是否在课程表中的课程号的范围之内。(9)创建规则,并绑定在向成绩表中添加记录时,如果成绩degree(select degree from score where sno= and cno=如图5所示。图5查询记录(2)查询课程号01大于课程号02
3、的最大值、并以分数降序排序的成绩表中所有列select * from score s where o= and s.degree=(select max(degree) from score y where o= ) order by degree descgo select max(degree) as 02max from score where cno=如图6所示。图6查询记录(3)查询性别为男的学号,姓名,班级,课程号和成绩的学生select student.sno,student.sname,student.class,o,score.degree from student,scor
4、e 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自定义数据类型exec s
5、p_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 teacher
6、 add tel varchar(15)8、创建视图(1)创建所有11班的学生信息的视图create view student11as select * from student where class=查看视图中的记录select * from student11如图10所示。图10查看视图(2)创建视图course_degree,其中的内容是选修计算机课程的学生信息,包括(sno,sname,cno,cname,degree),创建时加上with check optioncreate view course_degree(sno,sname,cno,cname,degree)select
7、score.sno,sname,o,cname,degree from course ,student, score where o=o and student.sno=score.sno and cname=with check optionselect * from course_degree如图11所示。图11查看视图(3)创建一个视图,其中的内容是成绩表中每门课程的create view averageselect avg(degree) as 平均分 from score group by cnoselect * from average 如图12所示。图12查看视图(4)创建视图其
8、中的内容是所有男教师和男学生的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约束的部分功能相同,在向表中的某列插入或更新数据时,用它来限制输入的新值的取值范围。而它与CHECK约束不同的是: CHECK约束是用CREATE TAB
9、LE语句在建表时指定的,而规则需要作为单独的数据库对象来实现。 在一个列上只能使用一个规则。但可以使用多个CHECK约束。 规则可以应用于多个列,还可以应用于用户自定义的数据类型,而CHECK约束只能应用于它定义的列。(1)创建一个degree_rule规则create rule degree_rule asvalues把此规则绑定到score表中degree列exec sp_bindrule degree_rulescore.degree(2) 创建一个tel_rule规则create rule tel_rule as value like 0-9 0-9 0-9 0-9 0-9 0-9 0
10、-9 0-9把此规则绑定到teacher表中tel列tel_ruleteacher.tel10、创建存储过程存储过程是存储在服务器上的例行程序及过程,在SQL SERVER只能感定义某个过程,其中记录了一系列的造作,每次应用程序只需调用该过程就可完成该操作,这种SQL SERVER中定义的过程就被称为存储过程。它可以完成以下功能: 接受输入参数并返回多个输出值。 包含T-SQL语句用以完成特定的SQL SERVER操作,其中可以有对其他存储过程的调用。 P返回一个指示成功与否及失败原因的状态代码给调用它的过程。存储过程不能接用过程名返回值,也不能直接在表达式中使用。(1)创建一个存储过程,来显
11、示成绩表中的课程号在课程表中并且所任教师性别为男、所在部门是计算机系的成绩表中的列create proc student_11select * from score where cno in (select cno from course ,teacher where course.tno=teacher.tno and depart= and tsex=调用此存储过程Execel student_11如图14所示。图14调用存储过程(2)创建一个带输入参数的存储过程,调用此存储过程时,给出一个学生名,显示出此学生的学号,姓名,所学课程号,课程名称和对应的成绩create proc student_namesname varchar(10)select student.sno,sname,o,degree cname from student,score,course where student.sno=score.sno and o=o and sname=sname调用此存储过程,(此例是输出姓名为历史的学生的信息)exec student_name 如图15所示。图15调用存储过程(3)创建一个存储过程,在执行此存储过程时,如果没有给出参数(学生姓名),则输入全部的学生的学号,姓名,班级,任课教师编号及其姓名,所
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1