Understanding expressions
This is an introduction to language expressions.
What is an expression ?
An expression is a sequence of operands, operators, and parentheses that the runtime system can evaluate as a single value. Operands are program variables, constants, functions returning a single value and literal values. Operators are used for arithmetic or string manipulation, and the parentheses are used to overwrite precedence of operators.
Language and SQL expressions
Expressions
in SQL statements are evaluated by the database server, not by the
runtime system. The set of operators that can appear
in SQL expressions resembles the set of language operators,
but they are not identical. A program can include SQL
operators, but these are restricted to SQL statements. Similarly,
most SQL operands are not valid in program expressions.
The SQL identifiers of databases, tables, or columns
can appear in a LIKE
clause or field name in program
instructions, provided that these SQL identifiers
comply with the naming rules of language. Here are
some examples of SQL operands and operators that cannot appear in
other language expressions:
- SQL identifiers, such as column names
- The SQL keywords
USER
andROWID
- Built-in or aggregate SQL functions that are not part of the language
- The
BETWEEN
andIN
operators - The
EXISTS
,ALL
,ANY
, orSOME
keywords of SQL expressions
Conversely, you cannot include language-specific operators in SQL expressions. For example:
- Arithmetic operators for exponentiation (
**
) and modulus (MOD
) - String operators
ASCII
,COLUMN
,SPACE
,SPACES
, andWORDWRAP
- Field operators
FIELD_TOUCHED()
,GET_FLDBUF()
, andINFIELD()
- The report operators
LINENO
andPAGENO
Parentheses in expressions
Parentheses are used as in algebra, to override the default order of precedence of operators. In mathematics, this use of parentheses represents the "associative" operator. It is, however, a convention in computer languages to regard this use of parentheses as delimiters rather than as operators. (Do not confuse this use of parentheses to specify operator precedence with the use of parentheses to enclose arguments in function calls or to delimit other lists.)
In this example, the variable y
is assigned the value of 2.
LET y = 15 MOD 3 + 2
In this example, y
is assigned the value of 0 because the parentheses
change the sequence of operations.
LET y = 15 MOD (3 + 2)