问题遇到的现象和发生背景
#举例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;
运行结果及报错内容
疑问
为什么最终结果是0?
是因为num这个参数出了loop循环结构后就失效了吗?
存储过程中的num属于什么变量?是会话用户变量还是局部变量,我怎么感觉两种都不符合啊
我想要达到的结果
正确输出累加后的值。必须要再定义一个局部变量才可以吗?