| 
 | [ NOT] | 
 | predicate | 
 | 
 | |||
| (search-condition) | ||||||||
| search-condition | 
 | AND | 
 | search-condition | ||||
| OR | ||||||||
This document covers the following topics:
A search-condition can consist of a simple
                              predicate or multiple
                                search-conditions. Multiple
                                search-conditions are combined with the
                            Boolean operators AND, OR and NOT, and can contain
                            parentheses if required to indicate a desired order of evaluation.
               
DEFINE DATA LOCAL 01 NAME (A20) 01 AGE (I2) END-DEFINE ... SELECT * INTO NAME, AGE FROM SQL-PERSONNEL WHERE AGE = 32 AND NAME > 'K' END-SELECT ...
| 
 | scalar-expression comparison | 
 | 
 | 
 | |||||||||||
| scalar-expression [ NOT]BETWEENscalar-expressionANDscalar-expression | |||||||||||||||
| scalar-expression IS[NOT]DISTINCT FROMscalar-expression | |||||||||||||||
| column-reference [ NOT]LIKE | 
 | 
 | [ ESCAPEatom] | ||||||||||||
| column-reference IS[NOT]NULL | |||||||||||||||
| scalar-expression [ NOT]IN | 
 | subquery | 
 | ||||||||||||
| 
 | 
 | 
 | ,... | 
 | |||||||||||
| scalar-expression comparison | 
 | 
                                                   | 
 | subquery | |||||||||||
| EXISTSsubquery | |||||||||||||||
| XMLEXISTS(xquery-expression-constant{BY
                                                  REF|PASSINGxquery-argument,...}) | |||||||||||||||
A predicate specifies a condition that can be
                              "true", "false" or "unknown".
               
In a search-condition, a
                                predicate can consist of a simple or complex
                            comparison operation or other kinds of conditions.
               
SELECT NAME, AGE 
  INTO VIEW PERS 
  FROM SQL-PERSONNEL 
  WHERE AGE BETWEEN 20 AND 30    
    0R AGE IN ( 32, 34, 36 ) 
    AND NAME LIKE '%er' 
    ...
                       Note
 The percent sign (%) may conflict with Natural
                                    terminal commands. If so, you must define a terminal command control
                               character different from %; see Changing the Terminal Command
                                      Control Character in the Terminal Commands
                               documentation.
                  
The individual predicates are explained in the following topics (for further information on predicates, please refer to the relevant literature). According to the syntax above, they are called as follows:
| 
 | scalar-expression | comparison | scalar-expression | 
 | ||
| row-value-expression | comparison | row-value-expression | ||||
A comparison predicate compares two values or a set of values with another set of values.
In the syntax diagram above, comparison can be one of the
                              following operators:
               
| = | equal to | 
| < | less than | 
| > | greater than | 
| <= | less than or equal to | 
| >= | greater than or equal to | 
| <> | not equal to | 
See information on scalar-expression.
               
| (select-expression) | 
A subquery is a
                                    select-expression that is nested inside
                                another such expression.
               
DEFINE DATA LOCAL 
1 #NAME    (A20) 
1 #PERSNR  (I4) 
END-DEFINE 
... 
SELECT NAME, PERSNR 
  INTO #NAME, #PERSNR 
  FROM SQL-PERSONNEL 
  WHERE PERSNR IN 
    ( SELECT PERSNR 
        FROM SQL-AUTOMOBILES 
        WHERE COLOR = 'black' )  
        ... 
END-SELECT
                           For further information, see Select Expressions.
| scalar-expression [ NOT]BETWEENscalar-expressionANDscalar-expression | 
A BETWEEN predicate compares a value with a range of values.
               
See information on scalar-expression.
               
| 
 | scalar-expression IS[NOT]DISTINCT FROMscalar-expression | 
 | 
| row-value-expression IS[NOT]DISTINCT FROMrow-value-expression | 
A DISTINCT predicate compares a value with another value or a set of
                              values with another set of values.
               
| column-reference [ NOT]LIKE | 
 | atom | 
 | [ ESCAPEatom] | 
| special-register | 
A LIKE predicate searches for strings that have a certain pattern.
               
See information on column-reference, atom and special-register.
               
| column-reference | 
 | IS[NOT]NULL | 
 | 
| ISNULL | |||
| NOTNULL | 
A NULL predicate tests for null values.
               
If the compiler option DB2ARRY is set to ON, it is possible
                                to specify an Natural array or an fixed index range of an array as atom. The Natural
                                SQL compiler will then decompose the array or fixed index range into a list of scalar
                                host variables. 
               
See information on column-reference.
               
| 
 | scalar-expression
                                                  [ NOT]IN | 
 | subquery | 
 | 
 | 
| row-value-expression | |||||
| row-value-expression  [ NOT]INsubquery | |||||
An IN predicate compares a value or a set of values with a collection of
                              values.
               
See information on scalar-expression, atom and special-register.
               
See information on subquery.
               
| 
 | scalar-expression | comparison | 
 | 
                                                     | 
 | subquery | 
 | 
| row-value-expression | = | 
 | 
                                                     | 
 | subquery | ||
| row-value-expression | <> | ALL | subquery | ||||
A quantified predicate compares a value or a set of values with a collection of values.
See information on scalar-expression, comparison and subquery.
               
| EXISTSsubquery | 
An EXISTS predicate tests for the existence of certain rows.
               
The EXISTS predicate evaluates to true only if the result of evaluating
                              the subquery is not empty; that is, if there
                              exists at least one record (row) in the FROM table of the
                                  subquery satisfying the search condition of
                              the WHERE clause of this
                              subquery.
               
 Example of EXISTS:
               
DEFINE DATA LOCAL 
1 #NAME    (A20) 
END-DEFINE 
... 
SELECT NAME 
  INTO #NAME 
  FROM SQL-PERSONNEL 
  WHERE EXISTS 
    ( SELECT * 
      FROM SQL-EMPLOYEES 
      WHERE PERSNR > 1000  
        AND NAME < 'L' ) 
        ... 
END-SELECT 
...
                         See information on subquery.
               
| XMLEXISTS(xquery-expression-constant | 
 | BY REF | 
 | ) | 
| PASSINGxquery-argument,... | 
| 
 | xquery-context-item-expression | 
 | 
| xquery-context-item-expression ASidentifier | 
The XMLEXISTS predicate belongs to the Natural SQL Extended Set.
               
The XMLEXISTS predicate tests whether an XPATH expression
                              returns a sequence of one or more items. For further information, see the IBM
                                Db2 XML Guide.