表: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
&nbs

本文介绍了Sybase数据库的存储过程,提供了一个示例,展示了如何创建和执行存储过程。内容包括:1) 创建存储过程的语法;2) 变量声明规则;3) 系统变量@adv_rowcount和@adv_error的作用;4) 如何检查SQL执行的错误和影响行数;5) 使用IF-ELSE进行业务判断。
最低0.47元/天 解锁文章
737

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



