ComeçarComece de graça

Criando funções nomeadas e declarando variáveis

Agora que você viu uma função de depuração poderosa em ação, vamos construir a sua própria. Primeiro, comece definindo a assinatura da função, que inclui o nome da função, quaisquer parâmetros e um tipo de retorno. A partir daí, é igual a uma função DO.

Este exercício faz parte do curso

Transações e Tratamento de Erros no PostgreSQL

Ver curso

Instruções do exercício

  • Defina uma função chamada debug_statement que receba uma instrução SQL como sql_stmt.
  • O tipo de retorno da função deve ser BOOLEAN.
  • A função deve executar a instrução SQL fornecida e capturar qualquer exceção.
  • A função deve retornar True se acionar a depuração e False caso não acione.

Exercício interativo prático

Experimente este exercício completando este código de exemplo.

-- 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 e executar o código