MySQL的autocommit是一個(gè)非常重要的設(shè)置,它決定了當(dāng)用戶執(zhí)行一個(gè)事務(wù)的時(shí)候,是自動(dòng)提交還是需要手動(dòng)提交。autocommit默認(rèn)是1,也就是說如果沒有顯式指定事務(wù),MySQL會(huì)將每個(gè)SQL語句都視作在一個(gè)事務(wù)中,并自動(dòng)提交。
但是,在一些特殊的情況下,我們需要手動(dòng)控制事務(wù)的提交行為,這時(shí)候就需要把a(bǔ)utocommit設(shè)置為0。下面是一個(gè)簡單的示例:
mysql>SET autocommit=0; -- 把a(bǔ)utocommit設(shè)置為0 Query OK, 0 rows affected (0.00 sec) mysql>START TRANSACTION; -- 開始一個(gè)事務(wù) Query OK, 0 rows affected (0.00 sec) mysql>INSERT INTO `users` (`name`, `age`) VALUES ('Tom', 18); -- 執(zhí)行SQL語句 Query OK, 1 row affected (0.00 sec) mysql>INSERT INTO `orders` (`user_id`, `product_name`, `price`) VALUES (1, 'book', 20); -- 執(zhí)行SQL語句 Query OK, 1 row affected (0.00 sec) mysql>COMMIT; -- 提交事務(wù) Query OK, 0 rows affected (0.00 sec)
這個(gè)示例展示了如何手動(dòng)控制事務(wù)的提交行為。首先把a(bǔ)utocommit設(shè)置為0,然后開始一個(gè)事務(wù),執(zhí)行一些SQL語句,最后手動(dòng)提交事務(wù)。
需要注意的是,如果不手動(dòng)提交事務(wù)而是直接關(guān)閉MySQL連接,那么事務(wù)也會(huì)自動(dòng)回滾。所以,在手動(dòng)控制事務(wù)的提交行為時(shí)一定要特別小心。