|
||||||||||||||||||||||
scalar-expression scalar-operator scalar-expression |
This document covers the following topics:
A scalar-expression
consists
of a factor or other scalar
expressions including scalar operators.
Concerning reference priority, scalar expressions behave as follows:
When a non-qualified variable name is specified in a scalar expression, the first approach is to resolve the variable name as column name of the referenced table.
If no column with the specified name is available in the referenced table, Natural tries to resolve this variable as a Natural user-defined variable (host variable).
+
|
||
-
|
||
*
|
||
/
|
||
| |
|
||
CONCAT
|
A scalar-operator
can be any
of the operators listed above. The minus (-) and slash (/) operators must be
separated by at least one blank from preceding operators.
Common Set Syntax:
Extended Set Syntax:
A factor
can consist of one
of the items listed in the above diagram and described in the text below.
parameter |
An atom can be either a
parameter
or a constant
.
column-name |
A column-reference
is a
column name optionally qualified by either a
table-name
or a correlation-name
(see also the section Basic Syntactical
Items). Qualified names are often clearer than unqualified
names and sometimes they are essential.
Note:
A table name in this context must not be qualified explicitly
with an authorization identifier. Use a correlation name instead if you need a
qualified table name.
If a column is referenced by a
table-name
or
correlation-name
, it must be contained
in the corresponding table. If neither a
table-name
nor a
correlation-name
is specified, the
respective column must be in one of the tables specified in the
FROM
clause (see Table
Expression).
Common Set Syntax:
COUNT
|
|||||||
( |
Extended Set Syntax:
|
( |
|
scalar-expression | ) | ||||||||
* |
||||||||||||
|
( |
|
scalar-expression ) | |||||||||
|
(scalar-expression-1,scalar-expression-2) |
SQL provides a number of special functions to enhance its basic retrieval power. The so-called SQL aggregate functions currently available and supported by Natural are:
Apart from COUNT(*)
, each of these functions operates
on the collection of scalar values in an argument (that is, a single column or
a scalar-expression
)
and produces a scalar value as its result.
Example:
DEFINE DATA LOCAL 1 AVGAGE (I2) END-DEFINE ... SELECT AVG (AGE) INTO AVGAGE FROM SQL-PERSONNEL ...
In general, the argument can optionally be preceded by the keyword
DISTINCT
to eliminate redundant duplicate values before the
function is applied.
If DISTINCT
is specified, the argument must be the
name of a single column; if DISTINCT
is omitted, the argument can
consist of a general scalar-expression
.
DISTINCT
is not allowed with the
special function COUNT(*)
, which is provided to count all rows
without eliminating any duplicates.
ROW CHANGE
|
TIMESTAMP |
FOR
table-designator |
||
TOKEN |
A ROW CHANGE
expression returns a token or a
timestamp that represents the last change to a row.
The following clauses of the OLAP Specification require the IBM Db2 Analytics Accelerator for z/OS:
CUME_DIST
PERCENT_RANK
NTILE
LAG
LEAD
FIRST_VALUE
LAST_VALUE
NTH_VALUE
RATIO_TO_REPORT
ordered-OLAP-specification |
CUME_DIST (
) |
OVER ([window-partition-clause]
window-order-clause)
|
|||
PERCENT_RANK (
) |
||||
RANK (
) |
||||
DENSE_RANK ( ) |
||||
NTILE
(num-tile) |
||||
lag-function |
||||
lead-function |
LAG
( expression [ ,
offset [ , default [ ,
|
'RESPECT NULLS' |
] ] ]
) |
||
'IGNORE
NULLS' |
LEAD
( expression [ ,
offset [ , default [ ,
|
'RESPECT NULLS' |
] ] ]
) |
||
'IGNORE
NULLS' |
ROW_NUMBER ( )
OVER ([window-partition-clause]
[window-order-clause])
|
aggregate-function | OVER ( [window-partition-clause])
|
||||
OLAP-column-function | |||||
RANGE BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED
FOLLOWING |
|||||
window-order-clause |
|
AVG function | ||
CORRELATION function | ||
COUNT function | ||
COUNT_BIG function | ||
COVARIANCE function | ||
MAX function | ||
MIN function | ||
STDDEV function | ||
SUM function | ||
VARIANCE function |
first-value-function | ||
last-value-function | ||
nth-value-function | ||
ratio-to-report-function |
FIRST_VALUE ( expression
[ , |
'RESPECT NULLS' |
] ) |
||
'IGNORE
NULLS' |
LAST_VALUE ( expression
[ , |
'RESPECT NULLS' |
] ) |
||
'IGNORE
NULLS' |
NTH_VALUE (
expression
|
,
nth-row ) |
RATIO_TO_REPORT (
expression )
|
|
|
BETWEEN
group-bound-1
AND
group-bound-2 |
|
|
|
PARTITION BY
partitioning-expression,...
|
ORDER
BY {sort-key-expression |
ASC |
},... | ||||
NULLS
LAST |
||||||
ASC
NULLS FIRST |
||||||
DESC |
||||||
DESC
NULLS FIRST |
||||||
DESC
NULLS LAST |
Online analytical processing (OLAP) specifications provide the
ability to return ranking, row numbering and aggregation information as a
scalar value in the result of a query. An OLAP specification can be included in
an expression, in a select-list, or in the ORDER BY
clause of a
SELECT
statement. The query result to which the OLAP
specifications are applied is the result table of the innermost subselect that
includes the OLAP specifications.
Example:
Display the ranking of employees that have a total salary of more than $30,000, in order by last name.
SELECT EMPNO, LASTNAME, FIRSTNME, SALARY+BONUS AS TOTAL_SALARY, RANK() OVER(ORDER BY SALARY+BONUS DESC) AS RANK_SALARY FROM DSN8910-EMP WHERE SALARY+BONUS > 30000 ORDER BY LASTNAME;
time-zone-specific-expression
Specifies a timestamp with time zone value:
AT
LOCAL
or
AT TIME
ZONE
AT
LOCAL
function-invocation |
{AT LOCAL }
|
AT TIME
ZONE
function-invocation |
{AT TIME ZONE }
|
function-invocation |
special-register
A reference to a special register returns a scalar value.
For more information on the special registers that are supported by Natural, see special-register in the section Syntactical Items Common to Natural SQL Statements in the Database Management System Interfaces documentation.
scalar-function
A scalar function is a built-in function that can be used in the construction of scalar computational expressions.
For information on the scalar functions that are supported by Natural, see scalar-function in the section Syntactical Items Common to Natural SQL Statements in the Database Management System Interfaces documentation.
labeled-duration
scalar-expression |
|
A labeled-duration
denotes a specific unit of time as expressed by a number which can be an
expression followed by one of the duration keywords.
labeled-duration
does not
conform to standard SQL, and is therefore supported by the Natural
SQL Extended Set
only.
case-expression
CASE
|
ELSE
|
END
|
A case-expression
does
not conform to standard SQL and is therefore supported by the Natural
SQL Extended Set
only.
WHEN
search-condition
THEN
|
A Searched When Clause does not conform to standard SQL and is therefore supported by the Natural SQL Extended Set only.
See details on search-condition
.
scalar-expression | WHEN
scalar-expression THEN
|
A Simple WHEN
Clause does not conform to standard
SQL and is therefore supported by the Natural
SQL Extended Set
only.
cast-expression
CAST
(scalar-expression
AS data-type)
|
A CAST
expression does not conform to standard SQL
and is therefore supported by the Natural
SQL Extended Set
only.
The option
user-defined-function-reference
belongs
to the Natural SQL Extended
Set. This option enables you to invoke any user-defined function.
Arguments have to be placed in brackets and separated by commas. The
user-defined function must be declared in the target RDBMS.
The option
sequence-reference
belongs to the
Natural SQL Extended
Set.
|
This option enables you to reference the next value or the previous value of a sequence object. The sequence object has to be created in the target RDBMS before it could be referenced at runtime.
(fullselect) |
The option
scalar-fullselect
belongs to the
Natural SQL Extended
Set.
A scalar-fullselect
as
supported in an expression is a
fullselect
- enclosed in parentheses -
that returns a single row consisting of a single column value. If the
fullselect
does not return a row, the
result of the expression is the null value. If more than one row is to be
returned for a scalar-fullselect
, an
error occurs.
(scalar-expression,...) |
A row-value-expression
returns a single row that consists of one or more column values. The values can
be specified as a list of expressions. The number of columns that are returned
by the row-value-expression
is equal to
the number of expressions.
row-value-expression
can be used as an
operand of several predicates (quantified,
DISTINCT
,
comparison,
and IN
).