- 1、本文档共78页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQLSERVER数据库原理及应用 _存储过程和触发器
第8章:存储过程和触发器;8.2存储过程的分类;1)系统存储过程:由系统自动创建,主要存储在master数据库中,一般以sp_为前缀。系统存储过程完成的功能主要是从系统表中获取信息。可以在其它数据库中调用系统存储过程。当创建一个新的数据库时,一些系统存储过程会在新数据库中被自动创建。;2)用户自定义存储过程:由用户创建并能完成某一特定功能的存储过程。;CREATE PROC P1
AS
Select sname, cname,degree
from student,score,course
Where student.sno=score.sno and score.cno=course.cno;3.使用存储过程的优点;3)使用存储过程可以减少网络流量;4.存储过程创建;3)创建存储过程应注意的事项: ;5.执行存储过程;6.修改存储过程;2)使用T-SQL语句修改存储过程
(1)重命名
sp_rename ‘原名称’,‘新名称,object
(2)修改定义
ALTER PROCEDURE author
AS
……;7.删除存储过程;8.存储过程参数化(重点、难点);1)创建带有输入参数的存储过程;Use school
GO
CREATE PROC spinsert
@sno char(5),
@sname char(8),
@ssex char(2),
@sbirthday datetime,
@class char(5)
AS
INSERT INTO student(sno,sname,ssex,sbirthday,class)
VALUES(@sno, @sname, @ssex, @sbirthday, @class) ;执行存储过程:
exec spinsert ‘111’,’张三’,’男’,’1980-1-1’,’95031’
上面例题创建的存储过程spinsert一共需要5个参数,并且因为没有给这些参数提供默认值,所以为了成功运行该存储过程,必须提供这些参数值。
如果执行如下语句:
exec spinsert ‘112’,‘李四’,‘男’,‘1985-1-2’
其中少了一个参数,尽管在基本表中该字段允许为空,但是此proc也不能被成功执行。;例题2:;Use school
GO
CREATE PROC spinsert
@sno char(5),
@sname char(8),
@ssex char(2),
@sbirthday datetime,
@class char(5)=‘95031’ --(或者@class char(5)=null)
AS
INSERT INTO student(sno,sname,ssex,sbirthday,class)
VALUES(@sno, @sname, @ssex, @sbirthday, @class) ;exec spinsert ‘112’,‘李四’,‘男’,‘1985-1-2’;Use school
GO
CREATE PROC average
@st_no int,
@st_name char(8) output,
@st_avg float output
AS
Select @st_name=student.sname,@st_avg=avg(score.degree)
From student,score where student.sno=score.sno
Group by student.sno,student.sname
Having student.sno=@st_no;Declare @st_name char(8)
Declare @st_avg float
Exec average 108,@st_name output,@st_avg output
Select ‘姓名’= @st_name ,’平均分’= @st_avg
Go ;Declare @st_name char(8)
Declare @st_avg float
Exec average 108,@st_name output,@st_avg output
Print @st_name
print @st_avg
Go ;Declare @st_name char(8)
Declare @st_avg float
Exec average 108,@st_name output,@st_avg output
Print @st_name +cast(@st_avg as char(4) )
Go ;9.存储过程的返回值; declare @b int
exec @b=spreturn
print @b;例
您可能关注的文档
- ChinaBuild-Profile-中国国际建筑装饰材料展览会-中英文简介doc-.doc
- CHMOS可编程时间间隔定时器芯片82C54.ppt
- Chinese ingredients 中餐原料 鱼翅燕窝培训(厨房培训) .ppt
- CISCO防火墙培训.ppt
- CMMI_ML3_访谈问题集之_PM_Questions.doc
- CN-I 型听力检查仪操作手册.doc
- cimatronE拆电极教程.doc
- CorelDRAW勾线.ppt
- CRM基础理论.pptx
- CL系列焊机是日本松下1983年在世界上首创采用了新技术....doc
- super-mega-oct-o-score-ticket-redemption-game-service-用户维护说明书手册-five-star.pdf
- power-putt-2013-video-golf-arcade-game-operators-service-用户维护说明书手册-its.pdf
- The-Beatles-Diamond-Edition-Pinball-Machine-Service-用户维护说明书手册-Stern-Pinball.pdf
- Star-Wars-Pro-Pinball-Machine-Service-用户维护说明书手册-Stern-Pinball.pdf
- the-grabber-money-machine-cash-cube-service-用户维护说明书手册-fun-industries.pdf
- super-bikes-2-video-arcade-game-用户维护说明书手册-rawthrills.pdf
- sink-it-shootout-ticket-redemption-arcade-game-service-用户维护说明书手册-baytek.pdf
- The-Walking-Dead-Video-Arcade-Game-Service-用户维护说明书手册-Raw-Thrills.pdf
- prize-hub-modular-ticket-redemption-center-service-用户维护说明书手册-baytek.pdf
- sharp-shooter-video-arcade-game-service-用户维护说明书手册-coastal-amusements.pdf
文档评论(0)