8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 01:23:03 +01:00
firebird-mirror/doc/sql.extensions/README.PSQL_stack_trace.txt

95 lines
2.0 KiB
Plaintext
Raw Normal View History

2005-01-26 15:49:49 +01:00
PSQL stack trace
Function:
Send to client within status-vector simple stack trace with names of stored procedures
2005-01-28 07:52:37 +01:00
and/or triggers. Status-vector appends with following items :
2005-01-26 15:49:49 +01:00
isc_stack_trace, isc_arg_string, <string length>, <string>
isc_stack_trace is a new error code with value of 335544842L
2005-01-28 07:52:37 +01:00
Stack trace is represented by one string and consists from all the sp/trigger names
starting from point where exception occurred up to most outer caller. Maximum length of
that string is 2048 bytes. If actual trace is longer then it will be truncated to this limit.
2005-01-26 15:49:49 +01:00
2005-01-28 07:52:37 +01:00
Author:
2008-05-13 09:26:32 +02:00
Vlad Khorsun <hvlad at users.sourceforge.net>
2005-01-26 15:49:49 +01:00
Examples:
2005-01-28 07:52:37 +01:00
0. Create metadata:
2005-01-26 15:49:49 +01:00
2005-01-28 07:52:37 +01:00
CREATE TABLE ERR (ID INT NOT NULL PRIMARY KEY, NAME VARCHAR(16));
2005-01-26 15:49:49 +01:00
CREATE EXCEPTION EX '!';
CREATE OR ALTER PROCEDURE ERR_1 AS
BEGIN
EXCEPTION EX 'ID = 3';
2005-01-28 07:52:37 +01:00
END;
2005-01-26 15:49:49 +01:00
CREATE OR ALTER TRIGGER ERR_BI FOR ERR BEFORE INSERT AS
BEGIN
IF (NEW.ID = 2)
THEN EXCEPTION EX 'ID = 2';
IF (NEW.ID = 3)
THEN EXECUTE PROCEDURE ERR_1;
IF (NEW.ID = 4)
THEN NEW.ID = 1 / 0;
END;
CREATE OR ALTER PROCEDURE ERR_2 AS
BEGIN
INSERT INTO ERR VALUES (3, '333');
END;
1. User exception from trigger:
SQL> INSERT INTO ERR VALUES (2, '2');
Statement failed, SQLCODE = -836
exception 3
-ID = 2
-At trigger 'ERR_BI'
2. User exception from procedure called by trigger:
SQL> INSERT INTO ERR VALUES (3, '3');
Statement failed, SQLCODE = -836
exception 3
-ID = 3
-At procedure 'ERR_1'
At trigger 'ERR_BI'
2005-01-28 07:52:37 +01:00
3. Division by zero occurred in trigger:
2005-01-26 15:49:49 +01:00
SQL> INSERT INTO ERR VALUES (4, '4');
Statement failed, SQLCODE = -802
arithmetic exception, numeric overflow, or string truncation
-At trigger 'ERR_BI'
4. User exception from procedure:
SQL> EXECUTE PROCEDURE ERR_1;
Statement failed, SQLCODE = -836
exception 3
-ID = 3
-At procedure 'ERR_1'
5. User exception from procedure with more deep call stack:
SQL> EXECUTE PROCEDURE ERR_2;
Statement failed, SQLCODE = -836
exception 3
-ID = 3
-At procedure 'ERR_1'
At trigger 'ERR_BI'
At procedure 'ERR_2'