Menangkap exception

Transaksi dan Penanganan Error di PostgreSQL

Jason Myers

Principal Engineer

Pernyataan yang error

INSERT INTO sales (name, quantity, cost) 
VALUES 
  ('chocolate chip', 6, null);
ERROR:  nilai null pada kolom "cost" melanggar batasan not-null
DETAIL:  Baris yang gagal berisi 
(1, "chocolate chip", 6, null, 2020-04-28 19:58:55.715886).
Transaksi dan Penanganan Error di PostgreSQL

Menangkap exception umum

R

tryCatch(
  sqrt("a"), 
  error=function(e) 
    print("Boom!")
)

Python

try:
   math.sqrt("a")
except Exception as e:
   print("Boom!")

PL/pgSQL

BEGIN 
SELECT 
  SQRT("a");
EXCEPTION WHEN others THEN RAISE INFO 'Boom!';
END;

Hasil

     R: Boom!
Python: Boom!
   SQL: INFO: Boom!
Transaksi dan Penanganan Error di PostgreSQL

Perintah PL/pgSQL DO (fungsi anonim)

DO $$

DECLARE some_variable text;
BEGIN SELECT text from a table; END;
$$ language 'plpgsql';
Transaksi dan Penanganan Error di PostgreSQL

Fungsi penanganan exception

DO $$
BEGIN
    SELECT SQRT("a");
EXCEPTION
    WHEN others THEN
       INSERT INTO errors (msg) VALUES ('Tidak bisa menghitung akar kuadrat dari string.');
       RAISE INFO 'Tidak bisa menghitung akar kuadrat dari string.';
END; 
$$ language 'plpgsql';
Transaksi dan Penanganan Error di PostgreSQL

Gunakan penanganan exception dengan bijak

  • Menggunakan klausa EXCEPTION menambah overhead signifikan
  • Penanganan exception di Python atau R lebih efisien
  • Jangan korbankan konteks yang tepat untuk menyelesaikan exception
  • Jangan optimalkan sebelum memahami exception Anda
1 https://www.postgresql.org/docs/12/plpgsql-control-structures.html {{1}}
Transaksi dan Penanganan Error di PostgreSQL

Mengubah data set

patients

column type
patient_id integer
a1c double (float)
glucose integer
fasting boolean
created_on timestamp

errors

column type
error_id integer
state string
msg string
detail string
context string
Transaksi dan Penanganan Error di PostgreSQL

Ayo berlatih!

Transaksi dan Penanganan Error di PostgreSQL

Preparing Video For Download...