11

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関数を実装する方法は??

ところで、私はMySQL5.5.8を使用しています

アーマンに感謝します。

4

2 に答える 2

9

はい、あります:SIGNALキーワードを使用します。

于 2011-02-01T13:20:45.613 に答える
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');
于 2013-05-20T07:18:16.857 に答える