Passing SAS Functions to Vertica

SAS/ACCESS Interface to Vertica passes the following SAS functions to Vertica for processing. Where the Vertica function name differs from the SAS function name, the Vertica name appears in parentheses. For more information, see Passing Functions to the DBMS Using PROC SQL.

ABS MAX
ARCOS (ACOS) MIN
ARSIN (ASIN) MINUTE
ATAN MONTH
ATAN2 QTR (QUARTER)
AVG REPEAT
BYTE SECOND
CEIL SIGN
COALESCE SIN
COS SQRT
EXP STD (STDDEV_SAMP)
FLOOR STRIP (BTRIM)
HOUR SUBSTR
INDEX (STRPOS) TAN
LENGTH TRANWRD (REPLACE)
LENGTHC (CHARACTER_LENGTH) TRIMN (RTRIM)
LENGTHN (LENGTH) UPCASE (UPPER)
LOG (LN) VAR (VAR_SAMP)
LOG10 (LOG) YEAR
LOWCASE (LOWER)

SQL_FUNCTIONS=ALL allows for SAS functions that have slightly different behavior from corresponding database functions that are passed down to the database. Only when SQL_FUNCTIONS=ALL can the SAS/ACCESS engine also pass these SAS SQL functions to Vertica. Due to incompatibility in date and time functions between Vertica and SAS, Vertica might not process them correctly. Check your results to determine whether these functions are working as expected.

COMPRESS (TRANSLATE) DTEXTDAY (DAYOFMONTH)
DATE (CURRENT_DATE) DTEXTWEEKDAY (DAYOFWEEK)
DATEPART (DATE) TIME (CLOCK_TIMESTAMP)
DATETIME (GETDATE) TIMEPART (CAST)
DAY (DAYOFMONTH) TODAY (CURRENT_DATE)
DTEXTYEAR (YEAR) TRANSLATE
DTEXTMONTH (MONTH) WEEKDAY (DAYOFWEEK)
Last updated: February 3, 2026