觸發(fā)器
什么是觸發(fā)器?觸發(fā)器的使用場景有哪些?
觸發(fā)器是用戶定義在關(guān)系表上的一類由事件驅(qū)動的特殊的存儲過程。
觸發(fā)器是指一段代碼,當(dāng)觸發(fā)某個事件時,自動執(zhí)行這些代碼。
使用場景
- 可以通過數(shù)據(jù)庫中的相關(guān)表實現(xiàn)級聯(lián)更改。
- 實時監(jiān)控某張表中的某個字段的更改而需要做出相應(yīng)的處理。
- 例如可以生成某些業(yè)務(wù)的編號。
- 注意不要濫用,否則會造成數(shù)據(jù)庫及應(yīng)用程序的維護困難。
- 大家需要牢記以上基礎(chǔ)知識點,重點是理解數(shù)據(jù)類型CHAR和VARCHAR的差異,表存儲引擎InnoDB和MyISAM的區(qū)別。
MySQL中都有哪些觸發(fā)器? 6`
在MySQL數(shù)據(jù)庫中有如下六種觸發(fā)器:
- Before Insert
- After Insert
- Before Update
- After Update
- Before Delete
- After Delete
觸發(fā)器的使用
創(chuàng)建觸發(fā)器
DELIMITER $
CREATE TRIGGER 觸發(fā)器名稱
BEFORE|AFTER INSERT|UPDATE|DELETE
ON 表名
[FOR EACH ROW] -- 行級觸發(fā)器
BEGIN
觸發(fā)器要執(zhí)行的功能;
END$
DELIMITER ;
- BEFORE|AFTER 表示是在操作之前還操作之后觸發(fā)
- INSERT|UPDATE|DELETE 是添加、修改、刪除的意思
- ON 表名 表示是對哪一張表進行添加、修改或者刪除的時候觸發(fā)我們要的操作
使用案例
這里是創(chuàng)建一個學(xué)生表,和一個操作記錄表
當(dāng)插入學(xué)生數(shù)據(jù)的時候,日志表就會啟動觸發(fā)器進行插入
1、創(chuàng)建表
CREATE TABLE `student` (
`id` varchar(64) NOT NULL,
`name` varchar(255) DEFAULT NULL,
`gender` tinyint(1) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
CREATE TABLE `student_log` (
`id` varchar(64) NOT NULL COMMENT '日志id',
`opt_type` varchar(1) DEFAULT NULL COMMENT '操作類型 i:插入 u:修改 d:刪除',
`opt_time` datetime DEFAULT NULL COMMENT '操作時間',
`opt_id` varchar(64) DEFAULT NULL COMMENT '操作id',
`data` varchar(255) DEFAULT NULL COMMENT '數(shù)據(jù)',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2、創(chuàng)建觸發(fā)器
create trigger student_log_insert
after insert # 插入之后處理
on student
for each row # 代表著每行都遵循這個規(guī)則
# 這里的new代表的是student這個表的新數(shù)據(jù)
begin
insert into student_log values(
new.id+"111",
'i',
NOW(),
new.id,
concat('{id=',new.id,';','name=',new.name,';','gender=',new.gender,';}')
);
end
3、查看觸發(fā)器是否成功
# 查看觸發(fā)器
show triggers
# 如果觸發(fā)器不符合自己的要求,可以刪除觸發(fā)器
DROP TRIGGER student_log_insert

image.png
4、測試
insert into student values("112154","i am walker",1);
insert into student values("11111","this is raina",1);
執(zhí)行結(jié)果之后,查看表,數(shù)據(jù)就出來了

image.png

image.png