如何在 MySQL 触发器中使用 SIGNAL 语句?
实际上,MySQL SIGNAL 语句是一种错误处理机制,用于处理意外情况并在需要时从应用程序优雅地退出。基本上,它向处理程序提供错误信息。其基本语法如下所示:
SIGNAL SQLSTATE | condition_value [SET signal_information_item = value_1,[, signal_information_item] = value_2, etc;]
这里,SIGNAL 关键字是 SQLSTATE 值或由 DECLARE CONDITION 语句声明的条件名称。SIGNAL 语句必须始终指定一个 SQLSTATE 值或一个定义了 SQLSTATE 值的命名条件。SQLSTATE 值由一个五字符的字母数字代码组成。我们不能以“00”开头我们自己的 SQLSTATE 代码,因为这些值表示成功,对于发出错误信号无效。如果我们的值无效,则会发生 Bad SQLSTATE 错误。对于通配符错误处理,我们应该分配 SQLSTATE 值“45000”,表示“未处理的用户定义异常”。
为了说明如何在 MySQL 触发器中使用 SIGNAL 语句,我们使用以下示例,其中我们在 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 语句抛出一个错误。
广告