Как сгенерировать ошибку в процедуре MySql? - PullRequest
11 голосов
/ 01 февраля 2011

Каков механизм, заставляющий MySQL выдавать ошибку в хранимой процедуре?

У меня есть процедура, которая вызывает другую функцию:

PREPARE my_cmd FROM @jobcommand;
EXECUTE my_cmd;
DEALLOCATE PREPARE my_cmd;

команда задания:

jobq.exec("Select 1;wfdlk# to simulatte an error");

затем:

CREATE PROCEDURE jobq.`exec`(jobID VARCHAR(128),cmd TEXT)
BEGIN
DECLARE result INT DEFAULT 0;  
SELECT sys_exec( CONCAT('echo ',cmd,' |  base64 -d > ', '/tmp/jobq.',jobID,'.sh ; bash /tmp/jobq.',jobID,'.sh &> /tmp/jobq.',jobID)) INTO result; 
IF result>0 THEN 
# call raise_mysql_error(result); 
END IF;
END;

Моя работа. exec всегда выполняется успешно.Есть ли способ вызвать ошибку?Как реализовать функцию lift_mysql_error ??

Кстати, я использую MySQL 5.5.8

спасибо, Арман.

Ответы [ 2 ]

9 голосов
/ 01 февраля 2011

Да, есть: используйте ключевое слово SIGNAL.

7 голосов
/ 20 мая 2013

Вы можете использовать следующую хранимую процедуру для эмуляции ошибок:

CREATE PROCEDURE `raise`(`errno` BIGINT UNSIGNED, `message` VARCHAR(256))
BEGIN
SIGNAL SQLSTATE
    'ERR0R'
SET
    MESSAGE_TEXT = `message`,
    MYSQL_ERRNO = `errno`;
END

Пример:

CALL `raise`(1356, 'My Error Message');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...