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

Arm*_*man 11 mysql stored-procedures stored-functions throw

什么是强制MySQL在存储过程中抛出错误的机制?

我有一个调用另一个函数的过程:

PREPARE my_cmd FROM @jobcommand;
EXECUTE my_cmd;
DEALLOCATE PREPARE my_cmd;
Run Code Online (Sandbox Code Playgroud)

job命令是:

jobq.exec("Select 1;wfdlk# to simulatte an error");
Run Code Online (Sandbox Code Playgroud)

然后:

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;
Run Code Online (Sandbox Code Playgroud)

我的职业.exec总是成功的.有没有办法引发错误?如何实现raise_mysql_error函数?

顺便说一下,我使用的是MySQL 5.5.8

谢谢阿曼.

小智 9

是的,有:使用SIGNAL关键字.

  • 谢谢!DECLARE CONTINUE HANDLER for SQLEXCEPTION SET err = 1正是我所需要的! (2认同)

Bli*_*itZ 7

您可以使用以下存储过程来模拟错误抛出:

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

例:

CALL `raise`(1356, 'My Error Message');
Run Code Online (Sandbox Code Playgroud)