|
ВОЗВРАТ ИЗ SQL SP SQLCODE И SQLSTATE ...
|
|||
---|---|---|---|
#18+
при выполнении SQL Stored Procedure в случае SQLEXCEPTION требуется выйти и вернуть значения SQLSTATE и SQLCODE - характеристики ошибки. Тогда: CREATE PROCEDURE myproc (OUT r_sqlstate CHAR(5), OUT r_sqlcode INTEGER) ... DECLARE SQLSTATE CHAR(5) DEFAULT '00000' ; DECLARE SQLCODE INTEGER DEFAULT 0; DECLARE EXIT HANDLER FOR SQLEXCEPTION BEGIN SET r_sqlstate = SQLSTATE ; SET r_sqlcode = SQLCODE ; END ; ... НО !!! см. manual: Note: When you access the SQLCODE or SQLSTATE variables in an SQL procedure, DB2 sets the value of SQLCODE to 0 and SQLSTATE to ‘00000’ for the subsequent statement. - Да, действительно, в моем случае после обращения к SQLSTATE эти переменные обнуляются, но я то еще не вычитал значение SQLCODE !!! Чего делать? ... |
|||
:
Нравится:
Не нравится:
|
|||
28.08.2003, 09:00 |
|
ВОЗВРАТ ИЗ SQL SP SQLCODE И SQLSTATE ...
|
|||
---|---|---|---|
#18+
Ты на жабе пишешь? Помнится там в кетч блоке можно прям так и писать: SQLException.getSQLSTATE , SQLException.getSQLCODE - точно синтаксис не помню, но что - то типа того. ... |
|||
:
Нравится:
Не нравится:
|
|||
28.08.2003, 12:11 |
|
ВОЗВРАТ ИЗ SQL SP SQLCODE И SQLSTATE ...
|
|||
---|---|---|---|
#18+
Т.е.: you don't need to access SQLCODE and SQLSTATE variables in procedure. Просто выполни процедуру и в случае эксепшена поймай в проге и ..см. пред. ансвер. ... |
|||
:
Нравится:
Не нравится:
|
|||
28.08.2003, 16:46 |
|
|
start [/forum/topic.php?fid=43&msg=32250375&tid=1606528]: |
0ms |
get settings: |
12ms |
get forum list: |
14ms |
check forum access: |
5ms |
check topic access: |
5ms |
track hit: |
63ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
51ms |
get tp. blocked users: |
2ms |
others: | 267ms |
total: | 435ms |
0 / 0 |