The UNITS operator
The UNITS SQL operator is specific to Informix SQL and needs to be
considered.
Basics about the UNITS operator
Informix SQL language provides the 
UNITS operator, to produce an
INTERVAL value from a single numeric
expression.expr UNITS {YEAR|MONTH|DAY|HOUR|MINUTE|SECOND|FRACTION(n)}Note: Do not confuse the 
UNITS operator in SQL statements, with the BDL language UNITS operator. The first is
processed by the SQL engine, while the BDL UNITS operator is processed by the
Genero runtime system and is independent from the database engine used by the program.UNITS is used in date/time arithmetic expressions, to increase or decrease one
of the time units in an INTERVAL, DATETIME or
DATE value, or to compare a date/time
interval:SELECT lead_time + 5 UNITS DAY FROM manufact;
SELECT * FROM cust_calls WHERE (TODAY - call_dtime) > 30 UNITS DAY;Adapting SQL statement using UNITS operator
The UNITS operator in SQL statements must be replaced by a portable SQL
expression.
The SQL expression can be modified to use a program variable as SQL parameter, that will be set
before executing the SQL statement.
Tip: When reviewing such SQL statements, try to
simplify the expressions, in order to ease the work of the SQL optimizer and use table indexes when
possible.
The following example:
DEFINE cnt INTEGER
SELECT COUNT(*) INTO cnt FROM cust_calls
   WHERE (TODAY - call_dtime) > 30 UNITS DAYCan be converted to compute the date limit in a program variable, before executing the SQL
statement:
DEFINE cnt INTEGER
DEFINE limit DATETIME YEAR TO SECOND
LET limit = CURRENT - 30 UNITS DAY
SELECT COUNT(*) INTO cnt FROM cust_calls
   WHERE call_dtime < limit