在PL/SQL编程语言的GOTO语句提供无条件跳转到在同一个子程序的GOTO标签的语句。
注意:GOTO语句是不建议使用在任何编程语言,因为它使得程序难以跟踪控制流程,使程序难以理解,难以修改。如果使用GOTO的任何程序可以改写,就尽量不要使用GOTO语句。
在PL/ SQL一个GOTO语句的语法如下:
GOTO label; |
.. |
.. |
<< label >> |
statement; |
DECLARE |
a number(2) := 10; |
BEGIN |
<<loopstart>> |
-- while loop execution |
WHILE a < 20 LOOP |
dbms_output.put_line ('value of a: ' || a); |
a := a + 1; |
IF a = 15 THEN |
a := a + 1; |
GOTO loopstart; |
END IF; |
END LOOP; |
END; |
/ |
当上述代码在SQL提示符执行时,它产生了以下结果:
value of a: 10 value of a: 11 value of a: 12 value of a: 13 value of a: 14 value of a: 16 value of a: 17 value of a: 18 value of a: 19 PL/SQL procedure successfully completed.
PL/SQL GOTO语句强加以下限制:
goto语句不能跳转到IF语句,CASE语句,循环语句或子块。
goto语句不能从一个分支IF语句子句到另一个或从一个CASE语句WHEN子句到另一个。
goto语句不能从外部块分支成子块(即一个内BEGIN-END块)。
goto语句不能分支出来一个子程序。提前结束子程序,要么使用RETURN语句或子程序结束前在正确的GOTO分支的地方。
goto语句不能从一个异常处理分支回到当前BEGIN-END块。但是,GOTO语句可以从一个异常处理程序跳转到一个封闭块。