mysql之觸發(fā)器使用
觸發(fā)器
什么是觸發(fā)器?觸發(fā)器的使用場(chǎng)景有哪些?
觸發(fā)器是用戶定義在關(guān)系表上的一類由事件驅(qū)動(dòng)的特殊的存儲(chǔ)過程。
觸發(fā)器是指一段代碼,當(dāng)觸發(fā)某個(gè)事件時(shí),自動(dòng)執(zhí)行這些代碼。
使用場(chǎng)景
- 可以通過數(shù)據(jù)庫(kù)中的相關(guān)表實(shí)現(xiàn)級(jí)聯(lián)更改。
- 實(shí)時(shí)監(jiān)控某張表中的某個(gè)字段的更改而需要做出相應(yīng)的處理。
- 例如可以生成某些業(yè)務(wù)的編號(hào)。
- 注意不要濫用,否則會(huì)造成數(shù)據(jù)庫(kù)及應(yīng)用程序的維護(hù)困難。
- 大家需要牢記以上基礎(chǔ)知識(shí)點(diǎn),重點(diǎn)是理解數(shù)據(jù)類型CHAR和VARCHAR的差異,表存儲(chǔ)引擎InnoDB和MyISAM的區(qū)別。
MySQL中都有哪些觸發(fā)器?
在MySQL數(shù)據(jù)庫(kù)中有如下六種觸發(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] -- 行級(jí)觸發(fā)器 BEGIN 觸發(fā)器要執(zhí)行的功能; END$ DELIMITER ;
- BEFORE|AFTER 表示是在操作之前還操作之后觸發(fā)
- INSERT|UPDATE|DELETE 是添加、修改、刪除的意思
- ON 表名 表示是對(duì)哪一張表進(jìn)行添加、修改或者刪除的時(shí)候觸發(fā)我們要的操作
使用案例
這里是創(chuàng)建一個(gè)學(xué)生表,和一個(gè)操作記錄表
當(dāng)插入學(xué)生數(shù)據(jù)的時(shí)候,日志表就會(huì)啟動(dòng)觸發(fā)器進(jìn)行插入
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 '操作時(shí)間', `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 # 代表著每行都遵循這個(gè)規(guī)則 # 這里的new代表的是student這個(gè)表的新數(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
4、測(cè)試
insert into student values("112154","i am walker",1); insert into student values("11111","this is raina",1);
執(zhí)行結(jié)果之后,查看表,數(shù)據(jù)就出來了
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
巧用mysql提示符prompt清晰管理數(shù)據(jù)庫(kù)的方法
隨著管理mysql服務(wù)器越來越多,同樣的mysql>的提示符有可能會(huì)讓你輸入錯(cuò)誤的命令到錯(cuò)誤的數(shù)據(jù)庫(kù),這時(shí)候需要巧用mysql的提示符,這是我的提示符root@localhost(mysql) 08:55:21> 用prompt命令實(shí)現(xiàn)(適用于windows和linux環(huán)境)2009-08-08深度解析MySQL啟動(dòng)時(shí)報(bào)“The server quit without up
這篇文章主要介紹了MySQL啟動(dòng)時(shí)報(bào)“The server quit without updating PID file”錯(cuò)誤的原因,需要的朋友可以參考下2017-05-05MySQL select、insert、update批量操作語(yǔ)句代碼實(shí)例
這篇文章主要介紹了MySQL select、insert、update批量操作語(yǔ)句代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn)(每個(gè)漢字轉(zhuǎn)換全拼)
這篇文章主要介紹了Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn),并且每個(gè)漢字會(huì)轉(zhuǎn)換全拼,使用Mysql自定義函數(shù)實(shí)現(xiàn),需要的朋友可以參考下2014-06-06MySQL存儲(chǔ)引擎的實(shí)現(xiàn)要素分析
這篇文章主要為大家介紹了MySQL存儲(chǔ)引擎的實(shí)現(xiàn)要素分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09Mysql一些復(fù)雜的sql語(yǔ)句(查詢與刪除重復(fù)的行)
這篇文章主要介紹了Mysql一些復(fù)雜的sql語(yǔ)句(查詢與刪除重復(fù)的行),需要的朋友可以參考下2017-05-05