凡是循环结构,一定具备4个要素:
- 初始化条件
- 循环条件
- 循环体
-
loop
LOOP循环语句用来重复执行某些语句。LOOP内的语句一直重复执行直到循环被退出(使用LEAVE子句),跳出循环过程。
语法
LOOP语句的基本格式如下:
[loop_label:] LOOP循环执行的语句END LOOP [loop_label]
其中,loop_label表示LOOP语句的标注名称,该参数可以省略。
例子
```sql DELIMITER // CREATE PROCEDURE test_loop() BEGIN
声明局部变量
DECLARE num INT DEFAULT 1;
loop_label:LOOP
#重新赋值SET num = num + 1;#可以考虑某个代码程序反复执行。(略)IF num >= 10 THEN LEAVE loop_label;END IF;
END LOOP loop_label;
查看num
SELECT num;
END //
DELIMITER ;
调用
CALL test_loop();
需求:<br />当市场环境变好时,公司为了奖励大家,决定给大家涨工资。声明存储过程“update_salary_loop()”,声明OUT参数num,输出循环次数。存储过程中实现循环给大家涨薪,薪资涨为原来的1.1倍。直到全公司的平均薪资达到12000结束。并统计循环次数。```sqlDELIMITER //CREATE PROCEDURE update_salary_loop(OUT num INT)BEGIN#声明变量DECLARE avg_sal DOUBLE ; #记录员工的平均工资DECLARE loop_count INT DEFAULT 0;#记录循环的次数#① 初始化条件#获取员工的平均工资SELECT AVG(salary) INTO avg_sal FROM employees;loop_lab:LOOP#② 循环条件#结束循环的条件IF avg_sal >= 12000THEN LEAVE loop_lab;END IF;#③ 循环体#如果低于12000,更新员工的工资UPDATE employees SET salary = salary * 1.1;#④ 迭代条件#更新avg_sal变量的值SELECT AVG(salary) INTO avg_sal FROM employees;#记录循环次数SET loop_count = loop_count + 1;END LOOP loop_lab;#给num赋值SET num = loop_count;END //DELIMITER ;SELECT AVG(salary) FROM employees;CALL update_salary_loop(@num);SELECT @num;
while
语法
WHILE语句创建一个带条件判断的循环过程。WHILE在执行语句执行时,先对指定的表达式进行判断,如果为真,就执行循环内的语句,否则退出循环。WHILE语句的基本格式如下:
[while_label:] WHILE 循环条件 DO循环体END WHILE [while_label];
while_label为WHILE语句的标注名称;如果循环条件结果为真,WHILE语句内的语句或语句群被执行,直至循环条件为假,退出循环。
例子
DELIMITER //CREATE PROCEDURE test_while()BEGIN#初始化条件DECLARE num INT DEFAULT 1;#循环条件WHILE num <= 10 DO#循环体(略)#迭代条件SET num = num + 1;END WHILE;#查询SELECT num;END //DELIMITER ;#调用CALL test_while();
需求:
市场环境不好时,公司为了渡过难关,决定暂时降低大家的薪资。声明存储过程“update_salary_while()”,声明OUT参数num,输出循环次数。存储过程中实现循环给大家降薪,薪资降为原来的90%。直到全公司的平均薪资达到5000结束。并统计循环次数。
DELIMITER //CREATE PROCEDURE update_salary_while(OUT num INT)BEGIN#声明变量DECLARE avg_sal DOUBLE ; #记录平均工资DECLARE while_count INT DEFAULT 0; #记录循环次数#赋值SELECT AVG(salary) INTO avg_sal FROM employees;WHILE avg_sal > 5000 DOUPDATE employees SET salary = salary * 0.9 ;SET while_count = while_count + 1;SELECT AVG(salary) INTO avg_sal FROM employees;END WHILE;#给num赋值SET num = while_count;END //DELIMITER ;#调用CALL update_salary_while(@num);SELECT @num;SELECT AVG(salary) FROM employees;
repeat
REPEAT语句创建一个带条件判断的循环过程。与WHILE循环不同的是,REPEAT 循环首先会执行一次循环,然后在 UNTIL 中进行表达式的判断,如果满足条件就退出,即 END REPEAT;如果条件不满足,则会就继续执行循环,直到满足退出条件为止。
语法
[repeat_label:] REPEAT循环体的语句UNTIL 结束循环的条件表达式END REPEAT [repeat_label]
repeat_label为REPEAT语句的标注名称,该参数可以省略;REPEAT语句内的语句或语句群被重复,直至expr_condition为真。
例子
DELIMITER //CREATE PROCEDURE test_repeat()BEGIN#声明变量DECLARE num INT DEFAULT 1;REPEATSET num = num + 1;UNTIL num >= 10END REPEAT;#查看SELECT num;END //DELIMITER ;#调用CALL test_repeat();
需求:
当市场环境变好时,公司为了奖励大家,决定给大家涨工资。声明存储过程“update_salary_repeat()”,声明OUT参数num,输出循环次数。存储过程中实现循环给大家涨薪,薪资涨为原来的1.15倍。直到全公司的平均薪资达到13000结束。并统计循环次数。
DELIMITER //CREATE PROCEDURE update_salary_repeat(OUT num INT)BEGIN#声明变量DECLARE avg_sal DOUBLE ; #记录平均工资DECLARE repeat_count INT DEFAULT 0; #记录循环次数#赋值SELECT AVG(salary) INTO avg_sal FROM employees;REPEATUPDATE employees SET salary = salary * 1.15;SET repeat_count = repeat_count + 1;SELECT AVG(salary) INTO avg_sal FROM employees;UNTIL avg_sal >= 13000END REPEAT;#给num赋值SET num = repeat_count;END //DELIMITER ;#调用CALL update_salary_repeat(@num);SELECT @num;SELECT AVG(salary) FROM employees;
三种循环结构对比
- 这三种循环都可以省略名称,但如果循环中添加了循环控制语句(LEAVE或ITERATE)则必须添加名称。
- LOOP:一般用于实现简单的”死”循环
- WHILE:先判断后执行
- REPEAT:先执行后判断,无条件至少执行一次
