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

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