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

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

軟件測試 | 創(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ā)器的評論 (共 條)

分享到微博請遵守國家法律
中方县| 长丰县| 荆门市| 鄂伦春自治旗| 曲沃县| 榆树市| 福鼎市| 广东省| 孙吴县| 浙江省| 西乌珠穆沁旗| 西安市| 格尔木市| 谢通门县| 永德县| 河源市| 利津县| 滨海县| 黎城县| 榆林市| 武冈市| 上高县| 耒阳市| 法库县| 兰州市| 金乡县| 呼伦贝尔市| 柳河县| 湟源县| 济宁市| 普宁市| 乾安县| 且末县| 庆阳市| 永安市| 合水县| 萝北县| 德昌县| 体育| 宜黄县| 常熟市|