sybase 存储过程 示例

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

表:student

列:STUDENT_ID, NAME, AGE, SEX,TEACHER_ID
表: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

    DECLARE @NUM 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。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值