强制MySQL在存储过程中抛出错误的机制是什么?
我有一个调用另一个函数的过程:
PREPARE my_cmd FROM @jobcommand;
EXECUTE my_cmd;
DEALLOCATE PREPARE my_cmd;
job命令是:
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
谢谢阿曼。