[email protected] writes:
catch postgresql exceptions when a foreingkey not exist in the table with which it interacts.
CREATE OR REPLACE FUNCTION calculo_pensionado_prueba(text)
RETURNS text AS
$BODY$
DECLARE
mensaje TEXT;
ultimo_registro INTEGER;
BEGIN
BEGIN
RAISE NOTICE 'inicia';
ultimo_registro = (SELECT CASE WHEN max(id) NOTNULL
THEN max(id) + 1 ELSE 1 END FROM calculonomina_periodo_calculo_temp);
INSERT INTO calculonomina_periodo_calculo_temp VALUES (ultimo_registro, 330, 10.00, 10.00, 100,NULL, 15, 569, 501, 183, '{"monto":"hola"}', 9135, 35, 1, 1, 124, 56, 'Pensionado');
--RAISE NOTICE 'despues del insert';
--EXECUTE 'DROP TABLE ' || $1;
EXCEPTION
WHEN FOREIGN_KEY_VIOLATION THEN
See the documentation to figure out what is the condition name that
matches with the SQL State you have:
http://www.postgresql.org/docs/9.4/interactive/errcodes-appendix.html
23503 foreign_key_violation
Also, you can see that you have two BEGIN, and it might be causing your
problem here, anyway I see no use for this construct, try removing one.
--
Dimitri Fontaine
PostgreSQL DBA, Architecte
--- SoupGate-Win32 v1.05
* Origin: fsxNet Usenet Gateway (21:1/5)