Capturing specific exceptions
Let's build a DO function that captures when glucose is set to null, and logs a message stating explicitly that Glucose can not be null.
Deze oefening maakt deel uit van de cursus
Transactions and Error Handling in PostgreSQL
Oefeninstructies
- Inside of the
BEGINblock of the DO function,INSERTintopatientsthe row (a1c=7.5,glucose=null, andfasting=TRUE). - Add a
not_null_violationexception that inserts"Glucose can not be null."in the detail column of errors in case of an error.
Praktische interactieve oefening
Probeer deze oefening eens door deze voorbeeldcode in te vullen.
-- Make a DO function
DO $$
-- Open a transaction block
BEGIN
INSERT INTO patients (a1c, glucose, fasting)
VALUES (7.5, ___, TRUE);
-- Catch an Exception
EXCEPTION
-- Make it catch not_null_constraint exception types
WHEN ___ ___
-- Insert the proper msg and detail
INSERT INTO errors (___, detail)
VALUES ('failed to insert', '___');
END$$;
-- Select all the errors recorded
SELECT * FROM errors;