如何使用 OLD 和 NEW 關鍵字訪問觸發器影響的行中的列?


眾所周知,在觸發器定義中,我們可以引用正在插入、更新或刪除的行中的列。以下是 OLD 和 NEW 關鍵字如何讓我們訪問列的方法:

  • 我們必須在列名前加上 OLD 限定符來引用原始行中的值。

  • 我們必須在列名前加上 NEW 限定符來引用新行中的值。

現在,必須適當地使用 OLD 和 NEW,因為觸發事件

決定了哪些是允許的:

  • 在 INSERT 觸發器中,NEW.column_name 表示要插入新行中的列值。此處不允許使用 OLD。

  • 在 DELETE 觸發器中,OLD.column_name 表示要刪除的行中列的值。此處不允許使用 NEW。

  • 在 UPDATE 觸發器中,OLD.column_name 和 NEW.column_name 分別表示行更新前後的列值。

換句話說,我們可以說 OLD 必須以只讀方式使用,而 NEW 可以用來讀取或更改列值。

在觸發器中使用 OLD 關鍵字

以下 DELETE 觸發器的示例展示了 OLD 的用法:

mysql> CREATE TRIGGER studentinfo_after_delete
   -> AFTER DELETE
   -> ON student_info
   -> FOR EACH ROW FOLLOWS
   -> BEGIN
   -> DECLARE vuser varchar(30);
   -> SELECT USER() into vuser;
   -> INSERT INTO student_info_deleted(id,deleted_date,deleted_by) VALUES(OLD.id,SYSDATE(),vuser);
   -> END; //
Query OK, 0 rows affected (0.25 sec)

在觸發器中使用 NEW 關鍵字

以下 INSERT 觸發器的示例展示了 NEW 的用法:

mysql> Create Trigger before_inser_studentage BEFORE INSERT ON
student_age FOR EACH ROW
BEGIN
IF NEW.age < 0 THEN SET NEW.age = 0;
END IF;
END //
Query OK, 0 rows affected (0.30 sec)

更新時間: 2019年7月30日

701 次瀏覽

開啟你的 職業生涯

透過完成課程獲得認證

開始學習
廣告

© . All rights reserved.