BaşlayınÜcretsiz Başlayın

Adlandırılmış işlevler oluşturma ve değişken bildirme

Artık güçlü bir hata ayıklama işlevini çalışırken gördüğüne göre, şimdi de kendi işlevini yazalım. Önce işlev imzasını tanımlayarak başla: işlev adı, varsa parametreler ve dönüş türünü belirt. Bundan sonrası, DO işleviyle aynıdır.

Bu egzersiz

PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi

kursunun bir parçasıdır
Kursu Görüntüle

Egzersiz talimatları

  • sql_stmt olarak bir SQL deyimi alan debug_statement adlı bir işlev tanımla.
  • İşlevin dönüş türü BOOLEAN olmalı.
  • İşlev, verilen SQL deyimini çalıştırmalı ve herhangi bir istisnayı yakalamalı.
  • İşlev, hata ayıklamayı tetiklerse True, tetiklemezse False döndürmeli.

Uygulamalı interaktif egzersiz

Bu örnek kodu tamamlayarak bu egzersizi bitirin.

-- 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);')
Kodu Düzenle ve Çalıştır