Mysql中怎么禁用与启动触发器
发布时间:2022-02-13 04:03:19 所属栏目:MySql教程 来源:互联网
导读:今天就跟大家聊聊有关Mysql中怎么禁用与启动触发器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 1.新建两张表: 表demo_1: CREATE TABLE `demo_1` ( `ID` int(11) NOT NULL AUTO_INCREMENT
今天就跟大家聊聊有关Mysql中怎么禁用与启动触发器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 1.新建两张表: 表demo_1: CREATE TABLE `demo_1` ( `ID` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键', `STUNAME` varchar(32) DEFAULT NULL COMMENT '名字', `AGE` tinyint(4) DEFAULT NULL COMMENT '年龄', PRIMARY KEY (`ID`) ) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=utf8; 表:demo_2 CREATE TABLE `demo_2` ( `ID` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键', `STU_ID` int(11) DEFAULT NULL COMMENT '学生编号', `MATH` double DEFAULT NULL COMMENT '成绩', PRIMARY KEY (`ID`) ) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8; 2.然后给demo_1创建一个触发器 DROP TRIGGER IF EXISTS `insertTragger`; DELIMITER ;; CREATE TRIGGER `insertTragger` AFTER INSERT ON `demo_1` FOR EACH ROW begin select ID INTO @v1 from demo_1 order by ID desc limit 1; Insert into demo_2(STU_ID, MATH) values(@v1, 98.5); end ;; DELIMITER ; 3.触发器是:在demo_1中添加一条数据时,demo_2中自动添加一条数据。 4.但是我不想每次出入数据都触发触发器呢,只有在我想触发的时候才触发。 重新编写触发器: DROP TRIGGER IF EXISTS `insertTragger`; DELIMITER ;; CREATE TRIGGER `insertTragger` AFTER INSERT ON `demo_1` FOR EACH ROW begin if @enable_trigger = 1 then select ID INTO @v1 from demo_1 order by ID desc limit 1; Insert into demo_2(STU_ID, MATH) values(@v1, 98.5); end if; end ;; DELIMITER ; 5.调用触发器 SET @enable_trigger = 1; INSERT INTO demo_1(STUNAME , AGE) VALUES(‘小强', 17); 执行之后,表demo_1中增加一条数据 2 小强 17 表demo_2中同样也增加一条数据 2 2 98.5 6.禁用触法器 SET @enable_trigger = 0; INSERT INTO demo_1(STUNAME , AGE) VALUES(‘小强', 17); 执行之后: 执行之后,表demo_1中增加一条数据 2 小强 17 看完上述内容,你们对Mysql中怎么禁用与启动触发器有进一步的了解吗? (编辑:我爱故事小小网_铜陵站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |