前言
解决复杂问题不可能通过一个 SQL 语句完成,我们需要执行多个 SQL 操作。流程控制语句的作用就是控制存储过程中 SQL 语句的执行顺序,是我们完成复杂操作必不可少的一部分。只要是执行的程序,流程就分为三大类:
- 顺序结构 :程序从上往下依次执行
- 分支结构 :程序按条件进行选择执行,从两条或多条路径中选择一条执行
- 循环结构 :程序满足一定条件下,重复执行一组语句
针对于MySQL 的流程控制语句主要有 3 类。注意:只能用于存储程序。
- 条件判断语句 :IF 语句和 CASE 语句
- 循环语句 :LOOP、WHILE 和 REPEAT 语句
- 跳转语句 :ITERATE 和 LEAVE 语句
分支结构之 IF
IF 表达式1
THEN 操作1
[ELSEIF 表达式2 THEN 操作2]
...
[ELSE 操作N]
END IF
符合表达式1就执行操作1,否则看下一个分支是否符合,以此类推。
分支结构之 CASE
CASE 表达式
WHEN 值1 THEN 结果1或语句1(如果是语句,需要加分号)
WHEN 值2 THEN 结果2或语句2(如果是语句,需要加分号)
...
ELSE 结果n或语句n(如果是语句,需要加分号)
END [case](如果是放在begin end中需要加上case,如果放在select后面不需要)
如果表达式符合值1就执行结果1。
或者
CASE
WHEN 条件1 THEN 结果1或语句1(如果是语句,需要加分号)
WHEN 条件2 THEN 结果2或语句2(如果是语句,需要加分号)
...
ELSE 结果n或语句n(如果是语句,需要加分号)
END [case](如果是放在begin end中需要加上case,如果放在select后面不需要)
条件1满足则执行结果1。
循环结构之 LOOP
循环语句是用来循环执行某些语句的,简化工作量。LOOP内的语句一直重复执行直到循环被退出(使用LEAVE子 句),跳出循环过程。
[loop_label:] LOOP
循环执行的语句 #使用LEAVE loop_label退出
END LOOP [loop_label]
其中,loop_label表示LOOP语句的标注名称,该参数可以省略。
循环结构之 WHILE
[while_label:] WHILE 循环条件 DO
循环体
END WHILE [while_label];
执行前先对循环条件做判断,如果循环条件成立,则执行,执行完一次循环体继续判断,直到条件为假退出循环。
循环结构之 REPEAT
[repeat_label:] REPEAT
循环体的语句
UNTIL 结束循环的条件表达式
END REPEAT [repeat_label]
REPEAT语句创建一个带条件判断的循环过程。与WHILE循环不同的是,REPEAT 循环首先会执行一次循环,然后在 UNTIL 中进行表达式的判断,如果满足条件就退出,即 END REPEAT;如果条件不满足,则会就继续执行循环,直到满足退出条件为止。
跳转语句之 LEAVE语句
LEAVE语句:可以用在循环语句内,或者以 BEGIN 和 END 包裹起来的程序体内,表示跳出循环或者跳出程序体的操作。
LEAVE 标记名
为BEGIN…END标记
begin_label: BEGIN
。。。
END;
跳转语句之 ITERATE 语句
ITERATE语句:只能用在循环语句(LOOP、REPEAT和WHILE语句)内,表示重新开始循环,将执行顺序 转到语句段开头处。
ITERATE label