Yığın tanılama ile özel durum yakalamayı geliştirme

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

Jason Myers

Principal Engineer

Daha fazla hata bilgisini yakalama

DO $$
BEGIN
   UPDATE inventory SET cost = 35.0 WHERE name = 'Macaron';
   UPDATE inventory SET cost = 3.50 WHERE name = 'Panellets';
EXCEPTION
   WHEN others THEN
       INSERT INTO errors (msg) VALUES ('Max cost is 10!');
       RAISE INFO 'Max cost is 10!';
END; 
$$ language 'plpgsql';
PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi

Yığın tanılamayı kullanma

DO $$
DECLARE
   exc_message text;
   exc_detail text;

BEGIN UPDATE inventory SET cost = 35.0 WHERE name = 'Macaron'; UPDATE inventory SET cost = 3.50 WHERE name = 'Panellets';
EXCEPTION WHEN others THEN GET STACKED DIAGNOSTICS exc_message = MESSAGE_TEXT, exc_detail = PG_EXCEPTION_DETAIL; INSERT INTO errors (msg, detail) VALUES (exc_message, exc_detail); RAISE INFO 'Exception Messaage: % | Exception Details: %', exc_message, exc_detail; END$$;
PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi

Örnek tanılama çıktısı

INFO:  Exception Messaage: new row for relation "inventory" violates check constraint 
"cost_check" | Exception Details: Failing row contains (7, 35, Macaron).
DO

postgres=# \x on
Expanded display is on.
postgres=# select msg, detail from errors;
-[ RECORD 1 ]-------------------------------------------------------------------
msg    | new row for relation "inventory" violates check constraint "cost_check"
detail | Failing row contains (7, 35, Macaron).
PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi

Neleri alabilirsiniz?

Ad Açıklama
RETURNED_SQLSTATE özel durumun SQLSTATE hata kodu
COLUMN_NAME özel durumla ilişkili sütunun adı
CONSTRAINT_NAME özel durumla ilişkili kısıtın adı
MESSAGE_TEXT özel durumun birincil iletisinin metni
PG_EXCEPTION_DETAIL varsa, özel durum ayrıntı iletisinin metni
1 https://www.postgresql.org/docs/12/plpgsql-control-structures.html
PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi

Daha fazla tanılama verisi

Ad Açıklama
PG_DATATYPE_NAME özel durumla ilişkili veri türünün adı
TABLE_NAME özel durumla ilişkili tablonun adı
SCHEMA_NAME özel durumla ilişkili şemanın adı
PG_EXCEPTION_HINT varsa, özel durum ipucu iletisinin metni
PG_EXCEPTION_CONTEXT özel durum anındaki çağrı yığınının satır(lar)ı
PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi

Hadi pratik yapalım!

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

Preparing Video For Download...