表:student
表:teacher
列:TEACHER_ID,NAME,AGE,SEX,SALARY,STUDENT_NUM
需求:将性别和年龄符合给定条件的学生,都指派给指定的老师,并将学生的数量,更新到teacher表中。
业务成功,则返回学生的数量,否则返回-1。
存储过程的代码:
CREATE PROCEDURE UPDATE_TEACHER_TABLE(@P_S_SEX VARCHAR(5),@P_AGE INT,@P_T_ID VARCHAR(10),@P_RESULT INT OUTPUT)AS
BEGIN
DECLARE @adv_rowcount INT
DECLARE @adv_error INT
SELECT @NUM=COUNT(STUDENT_ID) FROM student WHERE SEX=@P_S_SEX AND AGE=@P_AGE
UPDATE teacher SET STUDENT_NUM=@NUM WHERE TEACHER_ID=@P_T_ID
SELECT @adv_error = @@ERROR, @adv_rowcount=@@ROWCOUNT
IF @adv_error != 0 OR @adv_rowcount = 0
BEGIN
SET @P_RESULT = -1
END
ELSE
BEGIN
SET @P_RESULT =@NUM
END
END
在数据库中模拟测试存储过程的代码:
declare @P_RESULT int
EXEC UPDATE_TEACHER_TABLE '参数1', 参数2,'参数3',@P_RESULT OUTPUT
select @P_RESULT
解释:
1:创建存储过程的语法为:CREATE PROCEDURE 存储过程名字(输入参数1[,输入参数2...],输出参数)
AS
BEGIN
主体代码;
END
所有的参数,不论是输入参数还是输出参数都必须以@P_开头,输出参数放在最后,后面用OUTPUT标注。
2:所有的变量需要用declare来声明,必须以@ 开头。
3:DECLARE @adv_rowcount INT 和 DECLARE @adv_error INT 是声明系统变量,分别代表执行SQL后影响表的行数,和错误数量
4: SELECT @adv_error = @@ERROR, @adv_rowcount=@@ROWCOUNT 这句话紧跟在操作表的SQL之后。
用来查询前面的SQL执行之后,出现错误的数量和影响的行数。
5:通过IF ELSE来判断该执行什么业务。IF @adv_error != 0 OR @adv_rowcount = 0 代表,有错误,或者影响的行数为0。
本文介绍了Sybase数据库的存储过程,提供了一个示例,展示了如何创建和执行存储过程。内容包括:1) 创建存储过程的语法;2) 变量声明规则;3) 系统变量@adv_rowcount和@adv_error的作用;4) 如何检查SQL执行的错误和影响行数;5) 使用IF-ELSE进行业务判断。

763

被折叠的 条评论
为什么被折叠?



