SQL存储过程试题.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
--写存储过程及调用存储过程 /*1.写出创办分数存储过程用于计算某门课程成绩最高分、最低分、 平均分,参数课程号。*/ --2.写出统计某门课选人数的存储过程,输入参数课程号,输出参数人数。 /*3.创办存储过程,要求根据学生姓名查察学生的籍贯. (要求:在存储过程里定义两个参数, 第一个接收由调用程序指定的输入值 (学生姓名), 第二个参数用于将该值返回调用程序 )*/ /*4.程序职薪水表:ProWage 字段名称 数据种类 说明 ID int 自动编号,主键 PName Char(10) 程序员姓名 Wage int 薪水 创办一个存储过程,对程序员的薪水进行解析,月薪1500到10000不等,如果有百分之五 十的人薪水不到2000元,给所有人加薪,每次加100,再进行解析,直到有一半以上的人 大于2000元为止,存储过程执行完后,最终加了多少钱? 比方:如果有百分之五十的人薪水不到2000,给所有人加薪,每次加100元,直到有一半 以上的人薪水大于2000元,调用存储过程后的结果如图: 请编写T-SQL来实现如下功能: 盘问是否有一半程序员的薪水在2200、3000、3500、4000、5000或6000元之上,如果不到 分别每次给每个程序员加薪100元,至之一半程序员的薪水达到2200,3000,3500,4000, 5000或6000元。 /*5.编写一个存储过程PR_GET_PASS_RATE统计某门课程的及格率,其传入参数是课程号 P_CNO,传出参数是该课程成绩的及格率P_PASSRATE,及格率的格式形如:86.56%。 6.创办触发器T_1,功能是当向数据表学生增添记录时,显示学生的信息。 createtriggerT_1on学生 afterinsert asselect*from学生 insertinto学生values(3001,李四,男,计本10) 7.创办触发器T_2,功能是当向数据表班级增添、更正和删除记录时,显示学生的信息。 createtriggerT_2on学生 afterinsert,update,delete 精选文档 asselect*from学生 8.创办触发器T_3,功能是当更正班级班号,同步更新学生表的班号。 9.创办触发器T_4,功能是当删除学生表的记录时,同步删除选课表中的选课信息。 createtriggerT_4on学生 afterdelete as declare@xhchar(10) select@xh=学号fromdeleted deletefrom选课where学号=@xh deletefrom学生where学号=3002 /*1.写出创办分数存储过程用于计算某门课程成绩最高分、最低分、平均分,参数课程号。*/ usexsgl go createprocedureaa(@课程名nchar(16)) as begin select课程号,最高分=max(成绩),最低分=min(成绩),平均分=avg(成绩)from成绩where课程号=@课程名 groupby课程号 end go executeaa001 --2.写出统计某门课选人数的存储过程,输入参数课程号,输出参数人数。 usexsgl go createprocedurebb@课程号char(10),@人数intoutput as begin —2 精选文档 select@人数=(selectcount(课程号)from成绩 where课程号=@课程号) end declare@人数int,@课程号char(4) set@课程号=002 execbb@课程号,@人数output print课程号为+@课程号+的人数:+cast(@人数aschar(2)) /*3.创办存储过程,要求根据学生姓名查察学生的籍贯. (要求:在存储过程里定义两个参数, 第一个接收由调用程序指定的输入值(学生姓名), 第二个参数用于将该值返回调用程序)*/ usexsgl go createprocedurecc(@姓名char(10),@籍贯char(10)output) as begin select@籍贯=(select籍贯from学生 where姓名=@姓名) end declare@姓名char(10),@籍贯char(10) set@姓名=廖小小 execcc@姓名,@籍贯output print学生+@姓名+的籍贯是:+@籍贯 USEWage GO CREATETABLEProWage--程序职薪水表 ( IDintidentity(1,1)primarykey,--薪水编号 PNameCHAR(10)NOTNULL,--程序员姓名 WageintNOTNULL--薪水 ) GO --1、创办存储过程-- ifex

文档评论(0)

135****8681 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档