MySQL - 插入之前觸發器

歡迎,未來的數據庫魔法師們!今天,我們將深入MySQL的神奇世界,特別是「插入之前」觸發器。別擔心如果你是新手;我會一步步地引導你,就像我這些年來對無數學生所做的一樣。讓我們一起踏上這個令人興奮的旅程!

MySQL - Before Insert Trigger

MySQL插入之前觸發器是什麼?

想像你是一家豪華俱樂部的保鏢。你的工作是檢查每個進入的人。這正是插入之前觸發器對你的數據庫所做的!它是一個特殊的守護者,在新的數據被插入表中之前立即行動。

關鍵點:

  1. 它在INSERT操作之前自動激活。
  2. 它可以修改即將插入的數據,甚至完全阻止插入。
  3. 它是維護數據完整性和執行商業規則的強大工具。

現在,讓我們看看如何創建和使用這些觸發器!

創建基本的插入之前觸發器

讓我們從一個簡單的例子開始。假設我們有一個名為employees的表:

CREATE TABLE employees (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(50),
salary DECIMAL(10, 2),
hire_date DATE
);

現在,讓我們創建一個保證所有新員工的最低薪資為$30,000的觸發器:

DELIMITER //
CREATE TRIGGER before_employee_insert
BEFORE INSERT ON employees
FOR EACH ROW
BEGIN
IF NEW.salary < 30000 THEN
SET NEW.salary = 30000;
END IF;
END//
DELIMITER ;

讓我們分解這個過程:

  1. DELIMITER //:這會臨時更改分隔符,以便我們在觸發器中使用分號。
  2. CREATE TRIGGER before_employee_insert:我們正在給觸發器命名。
  3. BEFORE INSERT ON employees:這指定了觸發器應該在何時以及哪個表上激活。
  4. FOR EACH ROW:觸發器將對被插入的每行運行。
  5. BEGIN ... END:這包含我們觸發器的實際代碼。
  6. IF NEW.salary < 30000 THEN SET NEW.salary = 30000;:這是我們的邏輯。如果薪資過低,我們將它設為最低標準。
  7. DELIMITER ;:我們將分隔符改回分號。

現在,讓我們測試一下:

INSERT INTO employees (name, salary, hire_date) VALUES ('John Doe', 25000, '2023-05-01');
SELECT * FROM employees;

你會看到John的薪資已經被自動調整為$30,000。神奇,對吧?

高級插入之前觸發器示例

讓我們提升遊戲水平,使用一個更複雜的例子。我們將創建一個觸發器:

  1. 如果沒有提供,則自動將雇用日期設為今天。
  2. 確保名字是大寫開頭。
  3. 在另一個審計表中記錄插入。

首先,讓我們創建一個審計表:

CREATE TABLE employee_audit (
id INT AUTO_INCREMENT PRIMARY KEY,
action VARCHAR(50),
employee_id INT,
old_data TEXT,
new_data TEXT,
changed_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

現在,這是我們的高級觸發器:

DELIMITER //
CREATE TRIGGER before_employee_insert_advanced
BEFORE INSERT ON employees
FOR EACH ROW
BEGIN
-- 如果沒有提供雇用日期,則設為今天
IF NEW.hire_date IS NULL THEN
SET NEW.hire_date = CURDATE();
END IF;

-- 將名字轉換為大寫開頭
SET NEW.name = CONCAT(
UPPER(SUBSTRING(NEW.name, 1, 1)),
LOWER(SUBSTRING(NEW.name FROM 2))
);

-- 記錄插入
INSERT INTO employee_audit (action, employee_id, new_data)
VALUES ('INSERT', NEW.id, CONCAT('Name: ', NEW.name, ', Salary: ', NEW.salary, ', Hire Date: ', NEW.hire_date));
END//
DELIMITER ;

這個觸發器做了很多事:

  1. 檢查hire_date是否為NULL,如果是,則設為當前日期。
  2. 使用字符串函數將名字轉換為大寫開頭。
  3. 將插入記錄到我們的employee_audit表中。

讓我們測試一下:

INSERT INTO employees (name, salary) VALUES ('jANE smith', 40000);
SELECT * FROM employees;
SELECT * FROM employee_audit;

你會看到Jane的名字現在正確地被首字母大寫,她有了一個雇用日期,並且審計表中有一個條目!

使用客戶端程序使用插入之前觸發器

雖然我們一直在使用MySQL命令行,你也可以通過像MySQL Workbench或phpMyAdmin這樣的客戶端程序創建和使用觸發器。過程很相似:

  1. 連接到你的數據庫。
  2. 打開一個新的SQL腳本或查詢窗口。
  3. 將你的觸發器創建代碼粘貼進去。
  4. 執行腳本。

下面是一個在不同環境中創建觸發器的常用方法表:

環境 方法
MySQL CLI 直接輸入或粘貼觸發器代碼
MySQL Workbench 使用SQL編輯器編寫和執行觸發器代碼
phpMyAdmin 對於表單,導航到'觸發器'標籤,使用GUI或編寫SQL
應用程序代碼 使用數據庫連接庫執行創建觸發器的SQL

記住,無論使用哪種方法,SQL語法都是相同的!

結論

恭喜你!你剛剛踏入了MySQL觸發器的世界。我們已經介紹了基礎知識,創建了一些強大的觸發器,甚至還觸及了在不同環境中使用它們的方法。

在你繼續你的數據庫旅程時,記住觸發器就像是數據的沉默守護者。它們在背後辛勤工作,確保你的數據保持乾淨、一致並符合你的商業規則。

繼續練習,嘗試,最重要的是,樂在其中!誰知道呢?也許有一天你會成為教導新一代數據庫愛好者關於觸發器奇蹟的那個人。

快樂編程,願你的查詢總是返回你期望的結果!

Credits: Image by storyset