MySQL 関数内でのエラーの発生
MySQL は、データベースの機能を拡張するユーザー定義関数を定義するための強力なメカニズムを提供します。一部のシナリオでは、入力パラメーターを検証し、無効な値が見つかった場合にエラーを発生させることが重要です。 MySQL は、そのような状況に対処するためのさまざまなオプションを提供します。
シグナルの紹介
MySQL 5.5 では、他のプログラミング言語の例外からインスピレーションを得た強力なメカニズムであるシグナルが導入されています。シグナルを使用すると、開発者は関数からエラーを発生させ、呼び出し側でエラーを処理できます。
シグナルの発生
MySQL 関数内でシグナルを発生させるには、次の構文を使用します。
SIGNAL SQLSTATE 'error_code' SET MESSAGE_TEXT = 'error_message';
このステートメントでは、「error_code」は SQLSTATE 形式に従い、 「error_message」は、表示されるカスタム エラー メッセージです。例:
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Invalid parameter value';
シグナルの処理
関数の外側では、クライアントまたは呼び出し元は次の構文を使用してシグナルを処理できます:
DECLARE errerrno INT DEFAULT 0; DECLARE errmsg VARCHAR(255) DEFAULT ''; BEGIN ... Function call ... EXCEPTION WHEN SQLSTATE '45000' THEN SELECT SQLSTATE INTO errerrno; SELECT MESSAGE_TEXT INTO errmsg; ... Handle error with errerrno and errmsg ... END;
この例は、関数によって発生した '45000' SQLSTATE エラーを処理し、両方のエラーを取得する方法を示しています。さらなる処理のためのコードとメッセージ。
以上がMySQL ユーザー定義関数内でエラーを発生させて処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。