Ответ 1
Да, есть: SIGNAL
ключевое слово.
Каков механизм заставить 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
всегда преуспевает.
Есть ли способ поднять ошибку?
Как реализовать функцию raise_mysql_error?
BTW Я использую MySQL 5.5.8
спасибо Арману.
Да, есть: SIGNAL
ключевое слово.
Вы можете использовать следующую хранимую процедуру для эмуляции ошибок:
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');