PostgreSQL'de İşlemler (Transaction) ve Hata Yönetimi
Jason Myers
Principal Engineer
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';
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$$;
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).
| 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 |
| 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