如何将 SIGNAL 语句与 MySQL 触发器一起使用?
mysqlmysqli database
实际上,MySQL SIGNAL 语句是一种错误处理机制,用于处理意外事件并在需要时从应用程序中正常退出。基本上,它向处理程序提供错误信息。其基本语法如下 −
SIGNAL SQLSTATE | condition_value [SET signal_information_item = value_1,[, signal_information_item] = value_2, etc;]
此处,SIGNAL 关键字是 DECLARE CONDITION 语句声明的 SQLSTATE 值或条件名称。SIGNAL 语句必须始终指定 SQLSTATE 值或使用 SQLSTATE 值定义的命名条件。SIGNAL 语句的 SQLSTATE 值由五个字符的字母数字代码组成。我们不能用"00"开始我们自己的 SQLSTATE 代码,因为这样的值表示成功,并且不能用于发出错误信号。如果我们的值无效,则会出现 Bad SQLSTATE 错误。对于捕获所有错误处理,我们应该分配一个 SQLSTATE 值"45000",这表示"未处理的用户定义异常"。
为了说明 SIGNAL 语句与 MySQL 触发器的用法,我们使用以下示例,其中我们在 student_age 表上创建 BEFORE INSERT 触发器。如果我们尝试输入小于 0 的年龄,它将使用 SIGNAL 语句抛出一条错误消息。
示例
mysql> Create trigger before_insert_studentage BEFORE INSERT on student_age FOR EACH ROW BEGIN IF NEW.age<0 then SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'age less than 0'; END if; END; // Query OK, 0 rows affected (0.12 sec) mysql> Insert into student_age(age, name) values(-10,'gaurav')// ERROR 1644 (45000): age less than 0
从上面的结果集可以清楚地看出,如果我们尝试插入小于 0 的年龄,那么使用 SIGNAL 语句将引发错误。