1、第9章 存储过程的创建和使用 第9章 存储过程的创建和使用——例题解答 例9-2-1:创建一个名称为“StuInfo”的存储过程,要求完成以下功能:在T_STUDENT表中查询05541班学生的学号、姓名、性别、出生日期和政治面貌五个字段的内容。 在创建存储过程的窗口中,单击“查询”菜单,选择“指定模板参数的值”,会弹出“指定模板参数的值”对话框。 在“指定模板参数的值”对话框中将“Procedure_Name”参数对应的名称修改为“StuInfo”,单击“确定”按钮,关闭此对话框。在创建存储过程的窗口中将对应的SELECT语句修改为以下程序代码: Select S_NUM
2、BER AS 学号, S_NAME AS 姓名, SEX AS 性别, BIRTHDAY AS 出生日期, POLITY AS 政治面貌 FROM T_STUDENT WHERE LEFT(S_NUMBER,5)='05541' 输入完毕后,单击窗口工具栏上的“执行”按钮执行以上程序段,就会创建一个新的存储过程“StuInfo”。 例9-2-2:创建一个存储过程StuScoreInfo,完成的功能是在表T_STUDENT、表T_COURSE和表t_SCORE中查询以下字段:班级、学号、姓名、性别、课
3、程名称、考试分数。 程序清单如下: --打开STUDENT数据库 USE STUDENT --查询是否已存在此存储过程,如果存在,就删除它 IF EXISTS (SELECT name FROM sysobjects WHERE name = 'StuScoreInfo' AND type = 'P') DROP PROCEDURE StuScoreInfo GO --创建存储过程 CREATE PROCEDURE StuScoreInfo AS Select 班级=SUBSTRING(T_STUDENT.S_NUMBER,1, LE
4、N(T_STUDENT.S_NUMBER)-2), 学号=SUBSTRING(T_STUDENT.S_NUMBER, LEN(T_STUDENT.S_NUMBER)-1,2), S_NAME AS 姓名, SEX AS 性别, T_COURSE.C_NAME AS 课程名称, t_SCORE.SCORE AS 考试分数 FROM T_STUDENT,T_COURSE,t_SCORE WHERE T_STUDENT.S_NUMBER=t_SCORE.S_NUMBER AND T_COURSE.C_N
5、UMBER=t_SCORE.C_NUMBER GO 例9-2-3:创建一个带有参数的存储过程Stu_Info,该存储过程根据传入的学生编号,在T_STUDENT中查询此学生的信息。 程序清单如下: --删除已存在的存储过程 USE STUDENT IF EXISTS (SELECT name FROM sysobjects WHERE name = 'Stu_Info' AND type = 'P') DROP PROCEDURE Stu_Info GO --创建存储过程 USE STUDENT GO CREATE PROCED
6、URE Stu_Info @S_NUMBER varchar(10) AS Select 班级=SUBSTRING(T_STUDENT.S_NUMBER,1, LEN(T_STUDENT.S_NUMBER)-2), 学号=SUBSTRING(T_STUDENT.S_NUMBER, LEN(T_STUDENT.S_NUMBER)-1,2), S_NAME AS 姓名, SEX AS 性别, BIRTHDAY AS 出生日期, POLITY AS 政治面貌 FROM T_S
7、TUDENT WHERE S_NUMBER=@S_NUMBER GO 例9-2-4:创建一个带有参数的存储过程Stu_Age,该存储过程根据传入的学生编号,在T_STUDENT中计算此学生的年龄,并根据程序的执行结果返回不同的值,程序执行成功,返回整数0,如果执行出错,则返回错误号。 USE STUDENT IF EXISTS (SELECT name FROM sysobjects WHERE name = 'Stu_Age' AND type = 'P') DROP PROCEDURE Stu_Age GO --创建存储过程 USE
8、STUDENT GO CREATE PROCEDURE Stu_Age @S_NUMBER varchar(10), @Age int OUTPUT AS --定义并初始化局部变量,用于保存返回值 DECLARE @ErrorValue int SET @ErrorValue=0 --求此学生的年龄 SELECT @Age=YEAR(GETDATE())-YEAR(BIRTHDAY) FROM T_STUDENT WHERE S_NUMBER=@S_NUMBER --根据程序的执行结果返回不同的值 IF (@@ERROR<>0) SE
9、T @ErrorValue=@@ERROR RETURN @ErrorValue GO 例9-3-1:执行前面创建的StuInfo存储过程,它是一个无参的存储过程。 程序清单如下: USE STUDENT EXEC StuInfo 或直接写存储过程的名称: USE STUDENT GO StuInfo 例9-3-2:执行存储过程StuScoreInfo。 程序清单如下: USE STUDENT EXEC StuScoreInfo 例9-3-3:执行存储过程Stu_Info,该存储过程有一个输入参数“学号”,在执行时需要传入一个学号值。
10、 程序清单如下: USE STUDENT GO EXECUTE Stu_Info '0554101' 或: USE STUDENT GO EXECUTE Stu_Info @S_NUMBER='0554101' 例9-3-4:执行存储过程Stu_Age,该存储过程有一个输入参数“学号”,另外,还有一个输出参数@Age。存储过程执行完后,有一个返回的状态值,这个值可以从变量@ErrorValue得到。 程序清单如下: USE STUDENT GO DECLARE @stuAge int, @ReturnValue int,
11、@S_NUMBER char(10) SET @S_NUMBER='0554101' EXECUTE @ReturnValue=Stu_Age @S_NUMBER,@stuAge OUTPUT PRINT '本程序的执行结果:' PRINT '程序的返回值='+CAST(@ReturnValue AS char(2)) PRINT '学号为"'+RTRIM(@S_NUMBER)+'"的学生的年龄是' +CAST(@stuAge AS char(2))+'岁。' 或: USE STUDENT GO DECLARE @stuAge int, @ReturnV
12、alue int, @S_NUMBER1 char(10) SET @S_NUMBER1='0554101' EXECUTE @ReturnValue=Stu_Age @S_NUMBER=@S_NUMBER1, @Age=@stuAge OUTPUT PRINT '本程序的执行结果:' PRINT '程序的返回值='+CAST(@ReturnValue AS char(2)) PRINT '学号为"'+RTRIM(@S_NUMBER1)+'"的学生的年龄是' +CAST(@stuAge AS char(2))+'岁。' 例9-4-1:使用
13、系统存储过程查看Stu_Age存储过程的参数及其数据类型。 程序清单如下: --查看参数及其数据类型 USE STUDENT GO sp_help Stu_Age GO 例9-4-2:使用系统存储过程查看StuScoreInfo存储过程的相关的数据库对象。 程序清单如下: --查看相关的数据库对象 USE STUDENT GO sp_depends StuScoreInfo GO 例9-4-3:修改前面创建的Stu_Info存储过程,使之完成以下功能:根据传入的学号,在表T_STUDENT、表T_COURSE和表t_SCORE中查询此学生的班级、学号
14、姓名、性别、考试课程名称和考试分数。 程序清单如下: --修改存储过程 USE STUDENT GO ALTER PROCEDURE Stu_Info @S_NUMBER varchar(10) AS Select 班级=SUBSTRING(T_STUDENT.S_NUMBER,1,LEN(T_STUDENT.S_NUMBER)-2), 学号=SUBSTRING(T_STUDENT.S_NUMBER,LEN(T_STUDENT.S_NUMBER)-1,2), S_NAME AS 姓名, SEX AS 性别,
15、 T_COURSE.C_NAME AS 课程名称, SCORE AS 考试成绩 FROM T_STUDENT,T_COURSE,t_SCORE WHERE T_STUDENT.S_NUMBER=@S_NUMBER AND T_STUDENT.S_NUMBER=t_SCORE.S_NUMBER AND T_COURSE.C_NUMBER=t_SCORE.C_NUMBER GO 执行修改后的Stu_Info存储过程: USE STUDENT GO EXEC Stu_Info '0554101' GO 例9-5-1:使用系统存储过程将Stu_Info存储过程的名称修改为Stu_Info_SCORE。 程序清单如下: USE STUDENT GO Sp_rename Stu_Info, Stu_Info_SCORE GO 例9-5-2:使用DROP命令删除StuInfo和StuScoreInfo两个存储过程。 程序清单如下 USE STUDENT GO DROP procedure StuInfo, StuScoreInfo GO






