LoslegenKostenlos loslegen

Benannte Funktionen erstellen und Variablen deklarieren

Jetzt, da du eine leistungsfähige Debugging-Funktion in Aktion gesehen hast, baust du deine eigene. Beginne damit, die Funktionssignatur zu definieren: Sie enthält den Funktionsnamen, alle Parameter und einen Rückgabetyp. Danach verhält es sich wie bei einer DO-Funktion.

Diese Übung ist Teil des Kurses

Transaktionen und Fehlerbehandlung in PostgreSQL

Kurs anzeigen

Anleitung zur Übung

  • Definiere eine Funktion namens debug_statement, die eine SQL-Anweisung als sql_stmt entgegennimmt.
  • Der Rückgabetyp der Funktion soll BOOLEAN sein.
  • Die Funktion soll die übergebene SQL-Anweisung ausführen und dabei jede Exception abfangen.
  • Die Funktion soll True zurückgeben, wenn sie Debugging auslöst, und False, wenn nicht.

Interaktive Übung

Vervollständige den Beispielcode, um diese Übung erfolgreich abzuschließen.

-- 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);')
Code bearbeiten und ausführen