文档详情

SQLSERVER数据库原理及应用 _存储过程和触发器.ppt

发布:2017-05-04约5.28千字共78页下载文档
文本预览下载声明
第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;例
显示全部
相似文档