sybase 存储过程 示例

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

表: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
         
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值