TRY
The TRY expression ensures that errors caused by the input rows in the child (scalar) expression result in NULL for those rows, instead of causing the query to throw an error.
Examples
The following calls return errors when invoked without the TRY expression.
When they are wrapped into a TRY expression, they return NULL:
Casting
Without TRY
Query
SELECT 'abc'::INTEGER;Result
db error: ERROR: Could not convert string 'abc' to INT32With TRY
Query
SELECT TRY('abc'::INTEGER);Result
?column?---------- NULLInteger Overflow
Without TRY
Query
SELECT 127::TINYINT + 1::TINYINT;Result
db error: ERROR: Overflow in addition of INT8 (127 + 1)!With TRY
Query
SELECT TRY(127::TINYINT + 1::TINYINT);Result
?column?---------- NULLCasting Multiple Rows
Without TRY
Query
WITH cte AS (FROM (VALUES ('123'), ('test'), ('235')) t(a))SELECT a::INTEGER AS x FROM cte;Result
db error: ERROR: Could not convert string 'test' to INT32 when casting from source column aWith TRY
Query
WITH cte AS (FROM (VALUES ('123'), ('test'), ('235')) t(a))SELECT TRY(a::INTEGER) AS x FROM cte;Result
x------ 123 NULL 235Limitations
TRY cannot be used in combination with a volatile function, an aggregate function, or a scalar subquery.
For example:
Query
SELECT TRY(random())Result
db error: ERROR: TRY can not be used in combination with a volatile function