MySQL 是一種常見(jiàn)的關(guān)系型數(shù)據(jù)庫(kù),在實(shí)際應(yīng)用中,往往需要同時(shí)操作多個(gè)數(shù)據(jù)庫(kù)。而且,多個(gè)數(shù)據(jù)庫(kù)之間的操作可能存在依賴關(guān)系,需要保證事務(wù)的一致性。
MySQL 支持事務(wù)的原因是 InnoDB 存儲(chǔ)引擎提供了事務(wù)支持。在多庫(kù)事務(wù)中,首先需要確保所有涉及的庫(kù)都使用 InnoDB 引擎(MyISAM 引擎不支持事務(wù))。
CREATE TABLE `db1`.`users` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) NOT NULL,
`age` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
CREATE TABLE `db2`.`orders` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` int(11) NOT NULL,
`amount` decimal(10,2) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
以上代碼創(chuàng)建了兩個(gè)庫(kù) db1 和 db2,分別包含兩張表 users 和 orders。假設(shè)一個(gè)訂單必須綁定一個(gè)用戶,那么在插入訂單時(shí)需要先查詢?cè)撚脩羰欠翊嬖冢绻淮嬖趧t需要先插入用戶信息。此時(shí)就需要使用多庫(kù)事務(wù)。
START TRANSACTION;
USE db1;
INSERT INTO users (name, age) VALUES ('Tom', 20);
SET @user_id = LAST_INSERT_ID();
USE db2;
INSERT INTO orders (user_id, amount) VALUES (@user_id, 100);
COMMIT;
以上代碼使用START TRANSACTION
開(kāi)啟事務(wù),然后使用USE
命令切換庫(kù),并執(zhí)行插入操作。中間通過(guò)LAST_INSERT_ID()
函數(shù)獲取自增 ID。最后使用COMMIT
提交事務(wù)。
如果中間出現(xiàn)了任何錯(cuò)誤,可以通過(guò)ROLLBACK
回滾事務(wù),保證數(shù)據(jù)一致性。
START TRANSACTION;
USE db1;
INSERT INTO users (name, age) VALUES ('Tom', 20);
SET @user_id = LAST_INSERT_ID();
USE db2;
INSERT INTO orders (user_id, amount) VALUES (@user_id, 100);
-- ...
-- 中間出現(xiàn)錯(cuò)誤,回滾事務(wù)
ROLLBACK;
以上內(nèi)容簡(jiǎn)單介紹了 MySQL 多庫(kù)事務(wù)的使用方法,能夠幫助開(kāi)發(fā)者保障數(shù)據(jù)的一致性。