5.5 でこれを行う方法はないと思いますが、5.6+ に更新した場合は、次のことができます。
GET DIAGNOSTICSを使用してエラー情報にアクセスし、これらをエラー ログへの挿入の入力として使用しました。
たとえば、構造を作成します。
CREATE TABLE table_that_exists
(
column_that_exists INT(11) NOT NULL
, PRIMARY KEY (column_that_exists)
);
CREATE TABLE tbl_error_log
(
id INT(11) NOT NULL AUTO_INCREMENT
, err_no INT(4)
, err_msg VARCHAR(50)
, source_proc VARCHAR(50)
, PRIMARY KEY (id)
);
クエリを実行してエラーを生成し、SHOW_ERRORS の出力を表示します。
SELECT anything FROM table_that_exists;
SHOW ERRORS;
他の手順/エラー管理で使用するデータにアクセスする方法の例:
GET DIAGNOSTICS CONDITION 1
@P1 = MYSQL_ERRNO, @P2 = MESSAGE_TEXT;
SELECT @P1, @P2;
INSERT INTO tbl_error_log (err_no, err_msg, source_proc)
VALUES (@P1, @P2, 'sp_faulty_procedure');
SELECT * FROM tbl_error_log;