《mysql存储过程相关问题》

问题遇到的现象和发生背景

#举例2:当市场环境变好时,公司为了奖励大家,决定给大家涨工资。
#声明存储过程“update_salary_loop()”,声明OUT参数num,输出循环次数。
#存储过程中实现循环给大家涨薪,薪资涨为原来的1.1倍。直到全公司的平
#均薪资达到12000结束。并统计循环次数。

用代码块功能插入代码,请勿粘贴截图
DELIMITER //
CREATE PROCEDURE C(OUT num INT)
BEGIN
    DECLARE avg_sal DOUBLE DEFAULT 0;
    #初始条件
    SELECT AVG(salary) INTO avg_sal FROM employees ;
    SET num=0;
    loop_table:LOOP
        #循环条件
        #结束循环的条件
        IF avg_sal >=12000
            THEN LEAVE loop_table;
        END IF;
    
        #循环体
        #如果低于12000,更新员工工资
        UPDATE employees SET salary=salary*1.1;
        #迭代条件
        SELECT AVG(salary) INTO avg_sal FROM employees ;
        SET num=num+1;
    END LOOP loop_table;
        
END //


DELIMITER ;
CALL C(@aa);
SELECT @aa;

运行结果及报错内容

@aa=0

疑问

为什么最终结果是0?
是因为num这个参数出了loop循环结构后就失效了吗?
存储过程中的num属于什么变量?是会话用户变量还是局部变量,我怎么感觉两种都不符合啊

我想要达到的结果

正确输出累加后的值。必须要再定义一个局部变量才可以吗?

那可能是你的平均工资已经高于12000了呢,我试了下,没问题的

img