Previous Topic

Next Topic

If-Then-Else

Valid in: DBProc

The If-Then-Else statement chooses between alternate execution paths inside a database procedure.

Previous Topic

Next Topic

Syntax

The If-Then-Else statement has the following format:

IF boolean_expr THEN statement; {statement;}

              {ELSEIF boolean_expr THEN statement; {statement;}}

              [ELSE statement;{statement;}]

ENDIF

Previous Topic

Next Topic

Description

The If-Then-Else statement can only be issued from within the body of a database procedure.

A Boolean expression (boolean_expr) must always evaluate to true or false. A Boolean expression can include comparison operators ('=', '<>', and so on) and the logical operators and, or, not. Boolean expressions involving nulls can evaluate to unknown. Any Boolean expression whose result is unknown is treated as if it evaluated to false.

If an error occurs during the evaluation of an if statement condition, the database procedure terminates and control returns to the calling application. This is true for both nested and non-nested if statements.

Previous Topic

Next Topic

If Statement

The simplest form of the if statement performs an action if the Boolean expression evaluates to true. The syntax follows:

IF boolean_expr THEN
       statement; {statement;}
ENDIF

If the Boolean expression evaluates to true, the list of statements is executed. If the expression evaluates to false (or unknown), the statement list is not executed and control passes directly to the statement following the endif statement.

Previous Topic

Next Topic

If...Then Statement

The second form of the if statement includes the else clause. The syntax follows:

IF boolean_expr THEN
       statement; {statement;}
ELSE
       statement; {statement;}
ENDIF

In this form, if the Boolean expression is true, the statements immediately following the keyword are executed. If the expression is false (or unknown), the statements following the keyword else are executed. In either case, after the appropriate statement list is executed, control passes to the statement immediately following endif.

Previous Topic

Next Topic

If...Then...Elseif Statement

The third if variant includes the elseif clause. The elseif clause allows the application to test a series of conditions in a prescribed order. The statement list corresponding to the first true condition found is executed and all other statement lists connected to conditions are skipped. The elseif construct can be used with or without an else clause, which must follow all the elseif clauses. If an else clause is included, one statement list is guaranteed to be executed, because the statement list connected to the else is executed if all the specified conditions evaluate to false.

The simplest form of this variant is:

IF boolean_expr THEN
       statement; {statement;}
ELSEIF boolean_expr THEN
       statement; {statement;}
ENDIF

If the first Boolean expression evaluates to true, the statements immediately following the first then keyword are executed. In such a case, the value of the second Boolean expression is irrelevant. If the first Boolean expression proves false, however, the next Boolean expression is tested. If the second expression is true, the statements under it are executed. If both Boolean expressions test false, neither statement list is executed.

A more complex example of the elseif construct is:

IF boolean_expr THEN
       statement; {statement;}
ELSEIF boolean_expr THEN
       statement; {statement;}
ELSEIF boolean_expr THEN
       statement; {statement;}
ELSE
       statement; {statement;}
ENDIF

In this case, the first statement list is executed if the first Boolean expression evaluates to true. The second statement list is executed if the first Boolean expression is false and the second true. The third statement list is executed only if the first and second Boolean expressions are false and the third evaluates to true. Finally, if none of the Boolean expressions is true, the fourth statement list is executed. After any of the statement lists is executed, control passes to the statement following the endif.

Previous Topic

Next Topic

Nesting IF Statements

Two or more if statements can be nested. In such cases, each if statement must be closed with its own endif.

This example illustrates nested if statements in outline form:

Previous Topic

Next Topic

Permissions

All users are permitted to use this statement.

Previous Topic

Next Topic

Example: If-Then-Else

The following if statement performs a delete or an insert and checks to make sure the statement succeeded:

if (id > 0) and (id <= maxid) then
       delete from emp where id = :id;
       if iierrornumber > 0 then
              message 'Error deleting specified row';
              return 1;
       elseif iirowcount = 0 then
              message 'Specified row does not exist';
              return 2;
       endif;
elseif (id < maxid) then
       insert into emp values (:name, :id, :status);
       if iierrornumber > 0 then
              message 'Error inserting specified row';
              return 3;
       endif;
else
message 'Invalid row specification';
return 4;
endif;


© 2007 Ingres Corporation. All rights reserved.