/** * Test for function is_numeric * * Every test does raise division by zero if it failes */ BEGIN; -- Test if the function exists WITH test AS ( SELECT COUNT(*) AS exist , 0 AS zero FROM pg_catalog.pg_proc WHERE proname = 'is_numeric' ) SELECT CASE WHEN 1 / test.exist = 1 THEN TRUE ELSE (1 / zero)::BOOLEAN END AS res FROM test ; -- Test integer WITH test AS ( SELECT is_numeric('123') AS isnumeric , 0 AS zero ) SELECT CASE WHEN isnumeric THEN TRUE ELSE (1 / zero)::BOOLEAN END AS res FROM test ; -- Test a number with decimal separator WITH test AS ( SELECT is_numeric('123.456') AS isnumeric , 0 AS zero ) SELECT CASE WHEN isnumeric THEN TRUE ELSE (1 / zero)::BOOLEAN END AS res FROM test ; -- Test not a number WITH test AS ( SELECT is_numeric('1 2') AS isnumeric , 0 AS zero ) SELECT CASE WHEN NOT isnumeric THEN TRUE ELSE (1 / zero)::BOOLEAN END AS res FROM test ; ROLLBACK;