觸發器通常在操作某條數據時需要進行一些關聯操作是使用。
查看已創建觸發器:
SHOW TRIGGERS;
刪除名為xxxx的觸發器:
drop trigger xxxx;
?
創建觸發器 語法:
DELIMITER $$ CREATE /* [DEFINER = { user | CURRENT_USER }] */ TRIGGER `xxx`.`t_t3` BEFORE /AFTER INSERT/UPDATE/ DELETE ON `xxx`.` <Table Name> ` FOR EACH ROW BEGIN END$$ DELIMITER ;
BEFORE/AFTER :在操作這條數據之前/之后,進行其他操作
INSERT/UPDATE/
DELETE:選擇在什么樣的操作類型時觸發此觸發器
可以看一個栗子:
如:t_sys_log表有個類型為DATETIME的字段OPERATE_TIME,在修改時將此字段設為當前時間,
可創建如下觸發器:
DELIMITER $$ CREATE TRIGGER t_t2 BEFORE UPDATE ON t_sys_log FOR EACH ROW BEGIN SET NEW.OPERATE_TIME = NOW(); END $$ DELIMITER ;
隨便執行以下update?t_sys_log...可以看到OPERATE_TIME的時間被修改了
ps:順便說一下,關于修改時間字段隨數據修改二改動,mysql中還有一種方法,就是在創建字段時設為timestamp 并加上值屬性如下:
ALTER TABLE t_sys_log MODIFY operate_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP ;
但是這樣的屬性設置,每張表只能設置一個字段。
?
?
?
?
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
