|
|
The EXECUTE statement causes ALLBASE/SQL to execute a statement that
has been dynamically preprocessed by means of the PREPARE statement.
ISQL or Application Programs
EXECUTE {StatementName
[Owner.]ModuleName[(SectionNumber) ]}
[USING {[SQL]DESCRIPTOR{[INPUT]{SQLDA
AreaName1}
[AND OUTPUT{SQLDA
AreaName2}]
OUTPUT{SQLDA
AreaName}}
[INPUT]HostVariableSpecification1
[AND OUTPUT HostVariableSpecification2]
OUTPUT HostVariableSpecification
:Buffer[,:StartIndex[,:NumberOfRows]] }]
- StatementName
identifies a dynamically preprocessed statement to be executed in an
application program. The StatementName corresponds to one
specified in a previous PREPARE statement. This form of the
EXECUTE statement cannot be used interactively.
- [Owner.]ModuleName [(SectionNumber)]
identifies a dynamically preprocessed statement to be executed
interactively. The preprocessed statement cannot be a SELECT
statement. This form of the EXECUTE statement cannot be used in an
application program. If the section number is omitted, section number one
is assumed. You can omit the verb EXECUTE interactively.
- USING
allows dynamic parameter substitution in a prepared
statement in an application program.
- [SQL]DESCRIPTOR
indicates that a data structure of sqlda_type is used to pass dynamic
parameter information between the application and ALLBASE/SQL.
- SQLDA
specifies that a data structure of sqlda_type named sqlda is
used to pass dynamic parameter information between the application and
ALLBASE/SQL.
- AreaName
specifies the user defined name of a data structure of type sqlda_type
that is used to pass dynamic parameter information between the
application and ALLBASE/SQL.
- HostVariableSpecification
specifies host variable(s) that hold dynamic parameter values at run
time. The syntax of HostVariableSpecification is
presented separately below.
- INPUT
is the default for any EXECUTE statement and can be specified,
as required, for any type of prepared statement containing input dynamic
parameters.
- OUTPUT
is only allowed when the prepared statement is an
EXECUTE PROCEDURE statement. It can be used when the statement
contains output dynamic parameters.
- INPUT AND OUTPUT
is only allowed when the prepared statement is an
EXECUTE PROCEDURE statement. It can be used when the statement
contains both input and output dynamic parameters.
- Buffer
is a host variable array structure containing rows that are the input
for a BULK INSERT statement. This structure contains fields for
each column to be inserted and indicator variables for columns that can
contain null values. Whenever a column can contain nulls, an indicator
variable must be included in the array definition immediately after the
definition of that column. This indicator variable is an integer that can
have the following values:
- > = 0
the value is not NULL
- < 0
the value is NULL
 |
NOTE: To be consistent with standard SQL and to support portability
of code, it is strongly recommended that you use a -1 to
indicate a null value. However, ALLBASE/SQL interprets all negative
indicator variable values to mean a null value.
|
- StartIndex
is a host variable whose value specifies the array subscript denoting
where the first row to be inserted is stored; default is the first
element of the array.
- NumberOfRows
is a host variable whose value specifies the number of rows to insert;
default is to insert from the starting index to the end of the
array.
:HostVariableName [[INDICATOR]:IndicatorVariable] [,...]
- HostVariableName
specifies a host variable name that at run time contains the data
value that is assigned to a dynamic parameter defined in a prepared
statement.
Host variables must be specified in the same order as the dynamic
parameters in the prepared statement they represent. There must be a one
to one correspondence between host variable names and the dynamic
parameters in the prepared statement. A maximum of 1024 host variable
names can be specified.
- IndicatorVariable
names an indicator variable, whose value determines whether the
associated host variable contains a NULL value:
- > = 0
the value is not NULL
- < 0
the value is NULL
There must be a one to one mapping of the input and/or output
parameters in a prepared statement and its associated EXECUTE
statement.
INPUT is the default for any EXECUTE statement and can be
specified, as required, for any type of prepared statement.
The OUTPUT clause is only allowed when the prepared statement is
an EXECUTE PROCEDURE statement containing output dynamic
parameters.
An INPUT AND OUTPUT clause is only allowed when the prepared
statement is an EXECUTE PROCEDURE statement containing both
input and output dynamic parameters.
If StatementName is an EXECUTE PROCEDURE
statement without any input and output dynamic parameters, you can
execute the procedure by issuing EXECUTE
StatementName.
If StatementName is an EXECUTE PROCEDURE
statement with either input or output dynamic parameters, you can use
the EXECUTE USING statement with INPUT (default) or OUTPUT
option to execute the dynamically preprocessed statement.
If StatementName is an EXECUTE PROCEDURE
statement with both input and output dynamic parameters, you can use
the EXECUTE USING statement with the INPUT AND OUTPUT option
to execute the dynamically preprocessed statement.
Use the USING clause for either an SQLDA DESCRIPTOR or a
HostVariableSpecification for input and/or output
dynamic parameter substitution in a prepared statement.
The :Buffer [,:StartIndex
[,:NumberOfRows option is only used in association
with a BULK INSERT statement.
If StatementName is an EXECUTE PROCEDURE
statement, and there are multiple row result sets from the procedure,
you must use the procedure cursor method to retrieve result sets. A
warning is returned if a procedure cursor is not used in this case;
the return status and output parameters are returned as
usual.
In an application program, the EXECUTE statement does not require any
special authorization. The user running the program must have whatever
authorization is required by the dynamically preprocessed statement being
executed.
To use the EXECUTE statement in the interactive environment, you must
have RUN or OWNER authority for the dynamically preprocessed statement or have
DBA authority. In addition, the owner of the dynamically preprocessed statement
must have whatever authorization the dynamically preprocessed statement itself
requires.
Interactive execution
isql=> PREPARE Statistics(1)
> FROM 'UPDATE STATISTICS FOR TABLE PurchDB.Orders'
isql=> PREPARE Statistics(2)
> FROM 'UPDATE STATISTICS FOR TABLE PurchDB.OrderItems'
Two sections for module Statistics are stored in the
system catalog.
isql=> EXECUTE Statistics(1)
The statistics for table PurchDB.Orders are updated.
isql=> EXECUTE Statistics(2)
The statistics for table PurchDB.OrderItems are updated.
isql=> DROP MODULE Statistics
Both sections of the module are deleted.
Programmatic execution
If you know that the statement to be dynamically preprocessed is not
a SELECT statement and does not contain dynamic parameters,
you can prepare it and execute it in one step, as follows:
EXECUTE IMMEDIATE :Dynam1
You can prepare and execute the statement in separate operations. For
example, if you don't know the format of a statement, you could do
the following:
PREPARE Dynamic1 FROM :Dynam1
The statement stored in :Dynam1 is dynamically preprocessed.
DESCRIBE Dynamic1 INTO SqldaOut
If Dynamic1 is not a SELECT statement, the Sqld field of the
Sqlda data structure is 0. If you know there are no dynamic
parameters in the prepared statement, use the EXECUTE
statement to execute the dynamically preprocessed statement.
If it is possible that dynamic parameters are in the prepared
statement, you must describe the statement for input:
DESCRIBE INPUT Dynamic1 USING SQL DESCRIPTOR SqldaIn
If the prepared statement could be an EXECUTE PROCEDURE
statement (sqld = zero on DESCRIBE OUTPUT) with dynamic output
parameters, you must describe it for output:
DESCRIBE OUTPUT Dynamic1 USING SQL DESCRIPTOR SqldaOut
If only dynamic input parameters are present, the appropriate data
buffer or host variables must be loaded with the values of any
dynamic parameters. Then if the statement is not a query, it can be
executed, as in this example using a data buffer:
EXECUTE Dynamic1 USING SQL DESCRIPTOR SqldaIn
However, if the prepared statement is an EXECUTE PROCEDURE
statement with multiple row result sets (sqlmproc = non-zero) and
dynamic input and output parameters execute it as follows:
EXECUTE Dynamic1 USING SQL INPUT DESCRIPTOR SqldaIn
and OUTPUT DESCRIPTOR SqldaOut
|