mysql临时禁用触发器

mysql支持设定session变量,并且有带入到触发器中使用的能力,故可以间接的设置触发器失效

思路是:

在执行前设定一个session变量,执行过程中判断该变量的值(没有设定该变量的值时该变量默认值为null)

例:

set @disable_triggers = 1; 
UPDATE 
std_importpc pc  JOIN std_import_checked chk on pc.TrademarketCode in ('0','1') and chk.Texch = '.OF' 
and chk.SecuCode = pc.SecuCode 
set pc.checkedID = chk.ID; 
set @disable_triggers = NULL;

 

ALTER TABLE `std_importchoice` AUTO_INCREMENT=6854278; 
DROP TRIGGER IF EXISTS `TRG_PC_Checked`; 
DELIMITER ;; 
CREATE TRIGGER `TRG_PC_Checked` AFTER UPDATE ON `std_importpc` FOR EACH ROW 
begin

IF @disable_triggers IS NULL THEN 
update std_import_checked d set d.Version = now() , d.CheckedStatus = 3 where d.SecuCode  = new.SecuCode and d.TrademarketCode = new.TrademarketCode and d.CheckedStatus = 4;

End IF; 
end 
;; 
DELIMITER ;

(责任编辑:最模板)

转载于:https://my.oschina.net/qihaokeji/blog/705182

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值