觸發器通常在操作某條數據時需要進行一些關聯操作是使用。
查看已創建觸發器:
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元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

