MySQL 是一種流行的“關系型數據庫管理系統(RDBMS)”。在 MySQL 中,事務是一組操作,可以被視為一個單獨的工作單位。執行事務的每個操作都應該被視為原子操作,即要么全部成功,要么全部失敗。
START TRANSACTION;
SELECT @A:=MAX(salary) FROM employees WHERE department=1;
UPDATE employees SET salary=@A WHERE department=2;
COMMIT;
在上面的代碼中,首先使用 START TRANSACTION 語句開始一個事務。然后使用一個 SELECT 語句將結果存儲在一個變量中。接下來,UPDATE 語句會根據 SELECT 中檢索的最大工資更新員工表。最后使用 COMMIT 語句來提交事務并保存更改。如果一切順利,所有的操作都會成功。
存儲過程是一組預先定義的 SQL 代碼,可以重復使用并且可以在需要的時候被調用。存儲過程可用于執行一系列 SQL 語句,或者執行特定的任務。使用存儲過程可以將整個數據庫操作封裝在一起,供快速調用。
DELIMITER $$
CREATE PROCEDURE `add_employee` (
IN first_name VARCHAR(50),
IN last_name VARCHAR(50),
IN hire_date DATE,
IN job_title VARCHAR(50)
)
BEGIN
INSERT INTO employees (first_name, last_name, hire_date, job_title)
VALUES (first_name, last_name, hire_date, job_title);
END $$
DELIMITER ;
在上面的代碼中,我們創建了一個名為 add_employee 的存儲過程,該存儲過程接受四個輸入參數:first_name,last_name,hire_date 和 job_title。在存儲過程中,我們執行了 INSERT 語句將新員工添加到 employees 表中。使用存儲過程可以方便地執行常見任務,而無需每次都手動鍵入 SQL 代碼。