MySQL是一個(gè)開(kāi)源的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),其中包括觸發(fā)器這一特性。觸發(fā)器是MySQL中一種用于自動(dòng)執(zhí)行程序的數(shù)據(jù)庫(kù)對(duì)象,一般用于監(jiān)測(cè)和響應(yīng)數(shù)據(jù)庫(kù)的各種變化。
MySQL中觸發(fā)器的定義包括兩個(gè)主要部分:觸發(fā)事件和觸發(fā)程序。觸發(fā)事件是指所監(jiān)測(cè)的數(shù)據(jù)庫(kù)操作,例如INSERT、UPDATE、DELETE等。觸發(fā)程序是指當(dāng)滿足觸發(fā)事件時(shí)所要執(zhí)行的SQL語(yǔ)句序列。
以下是一個(gè)示例,定義了在student表中,當(dāng)有新的行被插入時(shí),觸發(fā)程序?qū)⒆詣?dòng)計(jì)算平均分,并將結(jié)果更新到avg_score表中:
CREATE TRIGGER tr_calc_avg_score AFTER INSERT ON student FOR EACH ROW BEGIN DECLARE total_score INT; DECLARE total_num INT; SET total_score = SELECT SUM(score) FROM student; SET total_num = COUNT(*) FROM student; INSERT INTO avg_score (average) VALUES (total_score / total_num); END;
值得注意的是,觸發(fā)器需要綁定到指定的表上,同時(shí)還需要指定觸發(fā)時(shí)機(jī)(例如在INSERT之后),以及是否為每行觸發(fā)。此外,在編寫觸發(fā)程序時(shí),需要小心不要產(chǎn)生死鎖或無(wú)限遞歸等問(wèn)題。