最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網 會員登陸 & 注冊

軟件測試 | 創(chuàng)建觸發(fā)器

2023-08-04 18:05 作者:愛測軟件測試  | 我要投稿

創(chuàng)建觸發(fā)器的語法如下:

注意:觸發(fā)器只能創(chuàng)建在永久表(Permanent Table)上,不能對臨時表(Temporary Table)創(chuàng)建觸發(fā)器。

其中 trigger_time 是觸發(fā)器的觸發(fā)時間,可以是 BEFORE 或者 AFTER,BEFORE 的含義指在檢查約束前觸發(fā),而 AFTER 是在檢查約束后觸發(fā)。

而 trigger_event 就是觸發(fā)器的觸發(fā)事件,可以是 INSERT、UPDATE 或者 DELETE。

對同一個表相同觸發(fā)時間的相同觸發(fā)事件,只能定義一個觸發(fā)器。例如,對某個表的不同字段的 AFTER 更新觸發(fā)器,在使用 Oracle 數據庫的時候,可以定義成兩個不同的 UPDATE 觸發(fā)器,更新不同的字段時觸發(fā)單獨的觸發(fā)器,但是在 MYSQL 數據庫中,只能定義成一個觸發(fā)

器,在觸發(fā)器中通過判斷更新的字段進行對應的處理。 使用別名 OLD 和 NEW 來引用觸發(fā)器中發(fā)生變化的記錄內容,這與其他的數據庫是相似的。

現在觸發(fā)器還只支持行級觸發(fā)的,不支持語句級觸發(fā)。 在樣例數據庫中,為 film 表創(chuàng)建了 AFTER INSERT 的觸發(fā)器,具體如下:

插入 film 表記錄的時候,會向 film_text 表中也插入相應的記錄

對于 INSERT INOT…ON DUPLICATE KEY UPDATE…語句來說,觸發(fā)觸發(fā)器的順序可能會造成疑惑。下面對 film 表分別創(chuàng)建了 BEFROE INSERT、AFTER INSERT、BEFORE UPDATE、AFTER UPDATE 觸發(fā)器,然后插入記錄,觀察觸發(fā)器的觸發(fā)情況:

從上面的例子可以知道,對于有重復記錄,需要進行 UPDATE 操作的 INSERT,觸發(fā)器觸發(fā)的順序是 BEFORE INSERT、BEFORE UPDATE、AFTER UPDATE;對于沒有重復記錄的 INSERT,就是簡單的執(zhí)行 INSERT 操作,觸發(fā)器觸發(fā)的順序是 BEFORE INSERT、AFTER INSERT。對于那些實際執(zhí)行 UPDATE 操作的記錄,仍然會執(zhí)行 BEFORE INSERT 觸發(fā)器的內容,在設計觸發(fā)器的時候一定要考慮這種情況,避免錯誤地觸發(fā)了觸發(fā)器。

軟件測試 | 創(chuàng)建觸發(fā)器的評論 (共 條)

分享到微博請遵守國家法律
天峨县| 万源市| 宁化县| 鹤壁市| 丰顺县| 沙河市| 青神县| 临漳县| 博爱县| 铁岭县| 建昌县| 美姑县| 吉木萨尔县| 淳化县| 两当县| 武邑县| 融水| 乐亭县| 涟源市| 通辽市| 卢龙县| 宁明县| 高要市| 株洲县| 夏邑县| 松阳县| 阿拉善右旗| 新平| 咸阳市| 越西县| 宜都市| 松原市| 肥城市| 贵州省| 咸丰县| 赤水市| 天津市| 东莞市| 汶川县| 屯昌县| 万全县|