如何在MySQL中禁用触发器?

时间:2012-11-28 05:02:20

标签: mysql database-trigger

在我的MySQL数据库中,我有一些触发器ON DELETEON INSERT。有时我需要禁用一些触发器,我必须DROP例如

DROP TRIGGER IF EXISTS hostgroup_before_insert //   

然后重新安装。是否有SET triggers hostgroup_before_insert = 0的快捷方式,就像我们对外键一样:

mysql> SELECT version();
+-------------------------+
| version()               |
+-------------------------+
| 5.1.61-0ubuntu0.10.10.1 |
+-------------------------+
1 row in set (0.00 sec)

编辑答案 MySQL中没有内置的服务器系统变量TRIGGER_CHECKS 一个简单的解决方法是改为使用用户定义的会话变量。

#FALSE value overrides trigger type settings
SET @TRIGGER_CHECKS = [TRUE|FALSE]; 

SET @TRIGGER_BEFORE_INSERT_CHECKS = [TRUE|FALSE];
SET @TRIGGER_AFTER_INSERT_CHECKS = [TRUE|FALSE];

DELIMITER $$
DROP TRIGGER IF EXISTS `yearCheck_beforeInsert` $$
CREATE DEFINER=`root`@`localhost` TRIGGER `yearCheck_beforeInsert`
BEFORE INSERT ON `movies` FOR EACH ROW 

#Patch starts here
thisTrigger: BEGIN
  IF ((@TRIGGER_CHECKS = FALSE)
      OR (@TRIGGER_BEFORE_INSERT_CHECKS = FALSE))
    AND (USER() = 'root@localhost') 

TRICK is Explained here

1 个答案:

答案 0 :(得分:4)

暂时不能禁用触发器。做一件事,使用一个全局变量。触发器将首先检查全局变量的值。在这种情况下,您可以更改全局变量的值以防止触发器的工作。

相关问题