存储过程复习题

上传人:汽*** 文档编号:560506853 上传时间:2023-12-16 格式:DOC 页数:4 大小:62.50KB
返回 下载 相关 举报
存储过程复习题_第1页
第1页 / 共4页
存储过程复习题_第2页
第2页 / 共4页
存储过程复习题_第3页
第3页 / 共4页
存储过程复习题_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《存储过程复习题》由会员分享,可在线阅读,更多相关《存储过程复习题(4页珍藏版)》请在金锄头文库上搜索。

1、(一)存储过程1、对学生课程数据库,编写2个存储过程,分别完成下面功能:1)统计某一门课的成绩分布情况,即按照各分数段统计人数,要求使用游标。 create proc TotalByCnoNum(cno varchar(6)asbegindeclare num1 int ,num2 int, num3 int,num4 int ,num5 int,grade int,cname char(20)select num1=0,num2=0,num3=0,num4=0,num5=0declare cur_cno cursor for select grade from sc where cno=cn

2、oopen cur_cnofetch next from cur_cno into gradewhile fetch_status=0beginif grade between 90 and 100set num1=num1+1else if grade between 80 and 89set num2=num2+1else if grade between 70 and 79set num3=num3+1else if grade between 60 and 69set num4=num4+1elseset num5=num5+1fetch next from cur_cno into

3、grade end close cur_cno deallocate cur_cno select cname=cname from course where cno=cno print 课程:+cname print 分数段人数统计print =print 90-100 : +convert(varchar(3),num1)print 80-89 : +convert(varchar(3),num2)print 70-79 : +convert(varchar(3),num3)print 60-69 : +convert(varchar(3),num4)print 不及格: +convert

4、(varchar(3),num5)print =end 执行以下语句,显示课程号为3的成绩情况:exec TotalByCnoNum 3运行结果如下:2)将学生选课成绩从百分制改为等级制(即A、B、C、D、E五级)。create proc ChangeGradeasbegindeclare dj char(1),cname char(20),cno char(6),sno char(9), grade intdeclare cur_cno cursor for select grade,cno,sno from scopen cur_cnofetch next from cur_cno int

5、o grade,cno,snoprint 学号 课程号 等级print =while fetch_status=0beginif grade between 90 and 100set dj=Aelse if grade between 80 and 89set dj=Belse if grade between 70 and 79set dj=Celse if grade between 60 and 69set dj=Delseset dj=Eprint sno+ +cno+ +djprint -fetch next from cur_cno into grade,cno,sno endp

6、rint =close cur_cnodeallocate cur_cnoend执行: exec ChangeGrade运行结果为:2、对SPJ数据库,1)创建一个存储过程ins_s_count,功能为根据提供的供应商号,供应商名,供应商所在地等信息,往S表中插入数据,并返回插入该记录之后,S表中的记录数。create proc ins_s_count(sno char(6),sname char(20),status char(10),city char(20)asbegindeclare num intinsert into s (sno,sname,status,city) values

7、(sno,sname,status,city)print 你添加的记录是:print =print 供应商号供应商名 状态 供应商所在地print +sno+sname+status+cityselect num=count(*) from sprint print =print 共有 +convert(varchar,num)+条记录end在s表中添加如下数据:exec ins_s_count S7,一建,120,杭州结果为:2) 调用该存储过程实现往S表中插入一条记录(S6,天盛,40福州),并显示插入该记录之后,S表中的记录数。 数据库脚本如第(1)题:exec ins_s_count

8、S6,天盛,40,福州J 创建一个存储过程,输入课程名称和课程编号,统计该门课程的选修次数create proc 选课次数名称 varchar(30),课程编号 char(8),选修次数 int=0 outputasif 名称 is nullbeginprint 请在调用存储过程时输入课程名称!return 1endif 课程编号 is nullbeginprint 请在调用存储过程时输入课程编号!return 1endif not exists(select * from 课程信息 where 名称=名称 and 课程编号=课程编号)beginprint 请输入正确的课程名称和代号!return 2endselect 选修次数=count(a.学号) from 选课信息 as a inner join 课程信息 as b on a.课程编号=b.课程编号 where b.名称=名称 and b.课程编号=课程编号if error0begin print 程序没有正常运行!return 3endreturn 0

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 医学/心理学 > 基础医学

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号