USER_FUNCTIONS

Returns metadata about user-defined SQL functions (which store commonly used SQL expressions as a function in the Vertica catalog) and User-Defined Functions (UDx).

Column Name Data Type Description
SCHEMA_NAME

VARCHAR

The name of the schema in which this function exists.

FUNCTION_NAME

VARCHAR

The name assigned by the user to the SQL function or User-Defined Function.

PROCEDURE_TYPE

VARCHAR

The type of user-defined function. For example, 'User Defined Function'.

FUNCTION_RETURN_TYPE

VARCHAR

The data type name that the SQL function returns.

FUNCTION_ARGUMENT_TYPE

VARCHAR

The number and data types of parameters for the function.

FUNCTION_DEFINITION

VARCHAR

The SQL expression that the user defined in the SQL function's function body.

VOLATILITY

VARCHAR

The SQL function's volatility (whether a function returns the same output given the same input). Can be immutable, volatile, or stable.

IS_STRICT

BOOLEAN

Indicates whether the SQL function is strict, where t is true and f is false.

IS_FENCED

BOOLEAN

Indicates whether the function runs in Fenced Mode or not.

COMMENT

VARCHAR

A comment about this function provided by the function creator.

Notes

  • The volatility and strictness of a SQL function are automatically inferred from the function definition in order that Vertica determine the correctness of usage, such as where an immutable function is expected but a volatile function is provided.
  • The volatility and strictness of a UDx is defined by the UDx's developer.

Example

Create a SQL function called myzeroifnull in the public schema:

=> CREATE FUNCTION myzeroifnull(x INT) RETURN INT
   AS BEGIN 
     RETURN (CASE WHEN (x IS NOT NULL) THEN x ELSE 0 END); 
   END;

Now query the USER_FUNCTIONS table. The query returns just the myzeroifnull macro because it is the only one created in this schema:

=> SELECT * FROM user_functions;
-[ RECORD 1 ]----------+---------------------------------------------------
schema_name            | public
function_name          | myzeroifnull
procedure_type         | User Defined Function
function_return_type   | Integer
function_argument_type | x Integer
function_definition    | RETURN CASE WHEN (x IS NOT NULL) THEN x ELSE 0 END
volatility             | immutable
is_strict              | f
is_fenced              | f
comment                |