mysql事務處理(轉)

ba發表於2007-08-16
mysql事務處理(轉)[@more@]預設的,MySQL 執行在 autocommit 模式。這就意味著,當你執行完一個更新時,MySQL 將立刻將更新儲存到磁碟上。

如果你使用事務安全表 (例如 InnoDB、BDB),透過下面的命令,你可以設定 MySQL 為非 autocommit 模式:

SET AUTOCOMMIT=0

在此之後,你必須使用 COMMIT 來儲存你的更改到磁碟上,或者使用 ROLLBACK ,如果你希望忽略從你的事務開始所做的更改。

如果你希望為一系列語句從 AUTOCOMMIT 模式轉換,你可以使用 START TRANSACTION 或 BEGIN 或 BEGIN WORK 語句:

START TRANSACTION;
SELECT @A:=SUM(salary) FROM table1 WHERE type=1;
UPDATE table2 SET summmary=@A WHERE type=1;
COMMIT;

START TRANSACTION 在 MySQL 4.0.11 中被加入;這是被推薦的開始一個特別(ad-hoc)事務的方式,因為這是 ANSI SQL 句法。

注意,如果你使用的是一個非事務安全表,更改會立刻被儲存,不受 autocommit 模式狀態的約束。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10617731/viewspace-961906/,如需轉載,請註明出處,否則將追究法律責任。

相關文章