如何在MySql存储过程中抛出错误?

12

如何在存储过程中强制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函数?

我正在使用MySQL 5.5.8


1
请参考以下链接:https://dev59.com/43RB5IYBdhLWcg3w7reV - Haim Evgi
请阅读本章节:http://www.docstoc.com/docs/687360/Error-Handling-In-Stored-Procedure,该章节与程序相关。 - Haim Evgi
2个回答

9
是的,可以使用 SIGNAL 关键字来实现。

3
谢谢!DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET err=1 正是我所需的! - Arman

7
您可以使用下列存储过程来模拟错误抛出:
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');

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接