Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to disable triggers in MySQL?

In my MySQL database I have some triggers ON DELETE and ON INSERT. Sometimes I need to disable some triggers, and I have to DROP e.g.

DROP TRIGGER IF EXISTS hostgroup_before_insert //    

and reinstall. Is there any shortcut to SET triggers hostgroup_before_insert = 0 like we have for foreign keys:

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

EDIT Answer There is no built-in server system variable TRIGGER_CHECKS in MySQL.
A simple workaround is to instead use a user-defined session variable.

#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')  

This TRICK is Explained here.

like image 780
Grijesh Chauhan Avatar asked Nov 28 '12 05:11

Grijesh Chauhan


People also ask

Can we disable the trigger?

To disable a DML trigger, at a minimum, a user must have ALTER permission on the table or view on which the trigger was created. To disable a DDL trigger with server scope (ON ALL SERVER) or a logon trigger, a user must have CONTROL SERVER permission on the server.

How do you stop a trigger in SQL?

In Object Explorer, connect to an instance of Database Engine and then expand that instance. Expand the database that you want, expand Tables, and then expand the table that contains the trigger that you want to disable. Expand Triggers, right-click the trigger to disable, and then click Disable.


1 Answers

Its not possible to temporarly disable triggers. Do one thing, use one global variable. Trigger will first check value of global variable first. In this case you can change value of global variable to prevent working of trigger.

like image 90
Fathah Rehman P Avatar answered Sep 19 '22 20:09

Fathah Rehman P