- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)