【发布时间】:2016-10-08 08:08:40
【问题描述】:
(第一次发帖。如果我违反任何习俗或协议,请道歉。)
我想为存储过程中抛出的任何 SQLWARNING 定义一个退出处理程序。但是处理程序被忽略了,它永远不会触发。我很困惑。
我正在使用 MariaDB v. 10.0.23。但是我已经在 MariaDB v. 10.1.14 上对此进行了测试,并得到了相同的结果。
以下是创建测试数据库的 SQL。
CREATE DATABASE testerrorhandling;
USE testerrorhandling;
CREATE TABLE test
(
int_notnull INT NOT NULL
);
DELIMITER //
CREATE DEFINER=CURRENT_USER PROCEDURE create_record
(
IN p INT
)
BEGIN
DECLARE EXIT HANDLER FOR SQLEXCEPTION
SELECT 'Handler for SQLEXCEPTION fired.';
DECLARE EXIT HANDLER FOR SQLWARNING
SELECT 'Handler for SQLWARNING fired.';
INSERT INTO test (int_notnull) VALUES (p);
END;
//
DELIMITER ;
如果我尝试添加一个空值,该过程会调用正确的处理程序。
MariaDB [testerrorhandling]> call create_record(null);
+---------------------------------+
| Handler for SQLEXCEPTION fired. |
+---------------------------------+
| Handler for SQLEXCEPTION fired. |
+---------------------------------+
1 row in set (0.00 sec)
但是现在如果我尝试添加一个非整数值,则会引发警告,但 SQLWARNING 错误处理程序永远不会触发。值 0 存储在 test 表中。
MariaDB [testerrorhandling]> call create_record('this is not an integer');
Query OK, 1 row affected, 1 warning (0.04 sec)
MariaDB [testerrorhandling]> show warnings;
+---------+------+---------------------------------------------------------------------------+
| Level | Code | Message |
+---------+------+---------------------------------------------------------------------------+
| Warning | 1366 | Incorrect integer value: 'this is not an integer' for column 'p' at row 1 |
+---------+------+---------------------------------------------------------------------------+
1 row in set (0.00 sec)
这不是我所期望或想要的。我一定是做错了什么。我在这里错过了什么?
【问题讨论】:
标签: mysql sql stored-procedures mariadb