mysql 触发器

1. 触发器mysql

创建触发器

CREATE TRIGGER trigger_name trigger_time
trigger_event ON tb_name FOR EACH ROW trigger_stmt 

trigger_name: --触发器的名称
trigger_time: --触发时间: 为BEFORE或者AFTER
trigger_event: --触发事件,为INSERT,DELETE或者update
tb_name: --表示建立触发器的表明,就是在哪张表上建立触发器:
trigger_stmt: 触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句所以可以说mysql创建以下六种触发器:

BEFORE INSERT,BEFORE DELETE,BFFORE UPDATE
AFTER INSERT,AFTER DELETE,AFTER UPDATE


-- BEFORE  在..之前
-- AFTER 在..之后
-- BEGIN 开始   end 结束

CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件
ON 表名 FOR EACH ROW
BEGIN
    执行语句列表
END



-- ips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突

--      为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||

--      当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;


 DELIMITER ||
 CREATE TRIGGER demo BEFORE DELETE
 ON users FOR EACH ROW
 BEGIN
 INSERT INTO logs VALUES(NOW());
 INSERT INTO logs VALUES(NOW());
 END
 ||
 DELIMITER ;
 
--  DELIMITER 分界符



-- 触发器类型         激活触发器的语句
INSERT 型触发器    INSERT ,LOAD DATA ,REPLACE
UPDATE 型触发器    UPDATE
DELETE 型触发器    DELETE,REPLACE


-- load data语句是将文件的内容插入到表中,相当于是insert语句,而replace语句在一般的情况下和insert差不多,但是如果表中存在primary 或者unique索引的时候,如果插入的数据和原来的primary key或者unique相同的时候,会删除原来的数据,然后增加一条新的数据,所以有的时候执行一条replace语句相当于执行了一条delete和insert语句。



DELIMITER $  #将语句的分隔符改为$
BEGIN
sql1;
sql2;
...
sqln
END $
DELIMITER ;  #将语句的分隔符改回原来的分号";"



DECLARE var_name var_type [DEFAULT value] #定义变量,可指定默认值
set var_name = value  #给变量赋值


#DELIMITER



#DELIMITER $
CREATE TRIGGER user_log AFTER INSERT ON users FOR EACH ROW
BEGIN
DECLARE s1 VARCHAR(40)character set utf8;
DECLARE s2 VARCHAR(20) character set utf8;
SET s2 = " is created";
SET s1 = CONCAT(NEW.name,s2);     #函数CONCAT可以将字符串连接
INSERT INTO logs(log) values(s1);
END #$
#DELIMITER ;


CREATE TABLE 'logs'(
'id' int(11) NOT NULL AUTO_INCREMENT,
'LOG' VARCHAR(255) default null cimment '日志说明',
PRIMARY KEY('ID')
)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值