ComenzarEmpieza gratis

Crear funciones con nombre y declarar variables

Ahora que has visto una potente función de depuración en acción, vamos a crear una propia. Empieza definiendo la firma de la función, donde indicarás el nombre, los parámetros (si los hay) y el tipo de retorno. A partir de ahí, es igual que una función DO.

Este ejercicio forma parte del curso

Transacciones y manejo de errores en PostgreSQL

Ver curso

Instrucciones del ejercicio

  • Define una función llamada debug_statement que reciba una sentencia SQL como sql_stmt.
  • El tipo de retorno de la función debe ser BOOLEAN.
  • La función debe ejecutar la sentencia SQL proporcionada y capturar cualquier excepción.
  • La función debe devolver True si activa la depuración y False si no lo hace.

Ejercicio interactivo práctico

Prueba este ejercicio y completa el código de muestra.

-- Define our function signature
___ ___ ___ ___ debug_statement(
    sql_stmt TEXT
)
-- Declare our return type
___ ___ AS $$
    DECLARE
        exc_state   TEXT;
        exc_msg     TEXT;
        exc_detail  TEXT;
        exc_context TEXT;
    BEGIN
        BEGIN
            -- Execute the statement passed in
            ___ sql_stmt;
        EXCEPTION WHEN others THEN
            GET STACKED DIAGNOSTICS
                exc_state   = RETURNED_SQLSTATE,
                exc_msg     = MESSAGE_TEXT,
                exc_detail  = PG_EXCEPTION_DETAIL,
                exc_context = PG_EXCEPTION_CONTEXT;
            INSERT into errors (msg, state, detail, context) values (exc_msg, exc_state, exc_detail, exc_context);
            -- Return True to indicate the statement was debugged
            ___ ___;
        END;
        -- Return False to indicate the statement was not debugged
        RETURN ___;
    END;
$$ LANGUAGE plpgsql;
SELECT debug_statement('INSERT INTO patients (a1c, glucose, fasting) values (20, 89, TRUE);')
Editar y ejecutar código