 |
» |
|
|
|
The EXECUTE PROCEDURE statement invokes a procedure. Scope |  |
ISQL or Application Programs Syntax |  |
EXECUTE PROCEDURE [:ReturnStatusVariable = ] [Owner.] ProcedureName [ ( [ ActualParameter ] [, [ ActualParameter ] ] [...] ) ] Parameters |  |
- ReturnStatusVariable
is an integer host variable,
or, for a prepared EXECUTE PROCEDURE statement, a dynamic parameter, that
receives the return status from the procedure.
ReturnStatusVariable can only be
used when invoking a procedure from an application program, and it is
always an output variable.
- [Owner.]ProcedureName
specifies the owner and
the name of the procedure to execute. If an owner name is not
specified, the owner is assumed to be the current DBEUserID.
- ActualParameter
specifies a parameter value that is passed into and/or
out of the procedure. The syntax of ActualParameter is presented
separately below.
SQL Syntax--ActualParameter |  |
[ParameterName = ] ParameterValue [OUTPUT [ONLY] ] Parameters--ParameterDeclaration |  |
- ParameterName
is the parameter name.
- ParameterValue
a value that is passed into and/or out of the procedure.
For an input only parameter, the value can be any expression that does not
include any aggregate function, add_months function, LONG column function,
TID function, local variable, procedure parameter, or built-in variable.
Column values are allowed only when the EXECUTE PROCEDURE statement is
defined in a rule.
For an OUTPUT or OUTPUT ONLY parameter, the value must be a single host variable,
or in a prepared EXECUTE PROCEDURE statement, a single dynamic parameter.
You can omit a parameter in calling
the procedure by using a comma by itself, which is equivalent to specifying a
value of NULL or the default (if one was defined when the procedure was
created). However, if a ParameterName is specified, use of a
comma by itself is disallowed.
- OUTPUT
specifies that the caller wishes to retrieve the output value of
the parameter. OUTPUT must also have been specified for
the corresponding parameter in the CREATE PROCEDURE statement.
If OUTPUT is not specified, no output value is returned to the caller.
- ONLY
specifies that the caller wishes to retrieve the output value
of the parameter and will not provide an input value.
You must also have specified ONLY for the corresponding parameter
in the CREATE PROCEDURE statement.
ONLY should be used, when applicable, to avoid unnecessary initialization of
procedure parameters.
Description |  |
You cannot execute a procedure from within another procedure.
If OUTPUT ONLY is not specified,
a parameter that is not given a value in the EXECUTE PROCEDURE
statement is assigned its default value if one was specified, or
otherwise NULL if the parameter was not declared NOT NULL.
If OUTPUT ONLY is not specified,
no value is provided for a parameter, a default is not specified,
and NOT NULL is specified, an error is returned and the
procedure is not executed.
If a procedure terminates abnormally (an error occurs in evaluating
the condition in an IF or WHILE statement, or in evaluating the expression in a
parameter or variable assignment), any cursors opened by the procedure
(including KEEP cursors) are closed. Otherwise, except in a procedure
invoked by a rule, any cursor opened by the procedure, and left open
when the procedure terminates, remains open and may therefore be
accessed when the procedure is executed again.
If OUTPUT has been specified for a parameter in both the CREATE PROCEDURE
and EXECUTE PROCEDURE statements, any changes made to the parameter
value within the procedure are returned to the calling application.
The actual parameter for an output parameter can be a host variable or
a dynamic parameter.
If you execute a procedure that returns multiple row result sets (contains
one or more SELECT statements with no INTO clause) without
using a procedure cursor, a warning is returned to
the application, no result set data is returned, and any
return status and output parameters are returned as usual.
You can execute procedures in ISQL, through
application programs, or via rules.
Further information on executing a procedure from an application is found
in the ALLBASE/SQL Advanced Application Programming Guide.
For the execution of procedures through rules, refer to the CREATE
RULE statement.
In ISQL, you cannot specify OUTPUT for a parameter. Although return status
cannot be specified in the EXECUTE PROCEDURE statement, ISQL does report
the return status.
Also, within ISQL, actual parameter values cannot include host variables.
If you attempt to execute a procedure that contains invalid
sections, ALLBASE/SQL silently revalidates the sections. You can
also use the VALIDATE statement to revalidate invalid sections in
procedures.
You can PREPARE and EXECUTE an EXECUTE PROCEDURE statement containing dynamic
parameters.
You can use EXECUTE PROCEDURE inside an EXECUTE IMMEDIATE statement, provided
the EXECUTE PROCEDURE statement includes neither dynamic parameters nor host
variables.
If you do not specify OUTPUT for a parameter declared as OUTPUT in the
CREATE PROCEDURE statement, no value is returned.
You cannot specify OUTPUT for a parameter not declared as OUTPUT in the
CREATE PROCEDURE statement.
OUTPUT ONLY must be specified for any parameter declared as OUTPUT
ONLY in the CREATE PROCEDURE statement if an actual parameter is provided.
Use of OUTPUT ONLY improves performance, since no time is
spent initializing the parameter to the input value, default value, or null.
Within a procedure, a single row SELECT statement (one having an INTO clause)
that returns multiple rows
will assign the first row to output parameters or local variables,
and a warning is issued. In an application, this case would generate an error.
Authorization |  |
You must have OWNER or EXECUTE authority for the procedure
or DBA authority to use this statement. Examples |  |
From an application program:
EXECUTE PROCEDURE :Status = Process12(:PartName, :Quantity,
:SalesPrice OUTPUT ONLY)
|
Within ISQL:
isql=> execute procedure Process12('Widget',150);
|
|