GOTO statement v17
The GOTO
statement causes the point of execution to jump to the statement with the specified label.
Syntax
The syntax of a GOTO
statement is:
label
is a name assigned to an executable statement. label
must be unique in the scope of the function, procedure, or anonymous block.
To label a statement, use this syntax:
statement
is the point of execution that the program jumps to.
Statements eligible for labeling
You can label assignment statements, any SQL statement (like INSERT
, UPDATE
, and CREATE
), and selected procedural language statements. The procedural language statements that can be labeled are:
IF
EXIT
RETURN
RAISE
EXECUTE
PERFORM
GET DIAGNOSTICS
OPEN
FETCH
MOVE
CLOSE
NULL
COMMIT
ROLLBACK
GOTO
CASE
LOOP
WHILE
FOR
exit
is considered a keyword and you can't use it as the name of a label.
Restrictions
GOTO
statements can't transfer control into a conditional block or sub-block. However, they can transfer control from a conditional block or sub-block.
GOTO
statements have the following restrictions:
- A
GOTO
statement can't jump to a declaration. - A
GOTO
statement can't transfer control to another function, or procedure. - Don't place a
label
at the end of a block, function, or procedure.
Example
This example verifies that an employee record contains a name, job description, and employee hire date. If any piece of information is missing, a GOTO
statement transfers the point of execution to a statement that prints a message that the employee isn't valid.