MySQL InnoDB 是一種支持事務的存儲引擎。所謂事務,即一組 SQL 命令,要么全部成功執行,要么全部失敗回滾。InnoDB 的事務有四種特性,稱為 ACID 特性:
- 原子性(Atomicity): 事務中的所有操作被視為一個整體,要么全部執行,要么全部失敗回滾。
- 一致性(Consistency): 事務的執行不能違反數據庫的完整性約束,即使事務失敗回滾。
- 隔離性(Isolation): 并發事務可以互不干擾,每個事務的執行都像是在獨立的環境中運行。
- 持久性(Durability): 事務成功完成后,其結果將被永久地保存在數據庫中,即使出現故障或重啟。
下面是一個簡單的示例,展示如何使用 InnoDB 的事務特性:
START TRANSACTION;
UPDATE account SET balance = balance - 100 WHERE user_id = 1;
INSERT INTO account_log (user_id, amount) VALUES (1, 100);
COMMIT;
以上代碼表示從用戶 id 為 1 的賬戶中扣除 100 元,并記錄到賬戶日志中。在 START TRANSACTION 和 COMMIT 之間的代碼是一個事務,它要么全部執行,要么全部回滾。
如果在上述事務執行期間,有另一個并發事務嘗試修改同一個賬戶的余額,InnoDB 會使用行級鎖機制來保證隔離性。
使用事務可以確保數據的一致性和完整性,但也會增加系統的開銷。因此,需要在使用事務時權衡好性能和數據的正確性。