10.MYSQL:什麼是事務?事務的應用?
所謂事務,其實就是相當於作業系統裡的原子性操作。它將一組對於資料庫表的操作繫結在一起,只有所有操作都成功,才提交,只要有一個操作失敗的話,那麼就不會提交。這樣的機制保證了資料庫資料的原子性、一致性、隔離性以及永續性。
首先還得明確,只有儲存引擎為INNODB的MYSQL資料庫這才支援事務!
要掌握事務機制,我們需要以下幾個知識點:
1)對於表的增刪改查的提交方式?
在MYSQL中,表的預設提交方式是自動提交(也即預設:autocommit=1),也就是對於表的操作是即時生效的。
可以通過set autocommit = 0; 修改為手動顯示提交!顯示提交的語句為 commit
2)事務如何開啟?
在MYSQL中,事務通過語句 start transactions 開啟!他等價於 set autocommit = 0。兩者寫一個就行了。
還有,在INNODB的鎖機制中, start transactions 等價於 unlock 解鎖操作
3)事務如何回滾?
記住!事務只支援 UPDATE/DELETE/INSERT語句的回滾,不支援SELECT/DROP/CREATE的回滾,但是事務處理塊中可以使用這幾條語句(SELECT/DROP/CREATE)。
rollback語句實現事務的回滾。預設情況下,回退到事務操作之前!在設定了儲存點之後,可回滾到相應的儲存點處!
4)如何設定儲存點?如何根據設定的儲存點進行回滾操作?
在每條操作之後新增語句 savepoint 儲存點名稱 即設定了對應操作的儲存點!
通過 rollback to 儲存點名稱 可以回滾到相應的儲存點,不過記住回滾點之前的操作都是生效的,回滾點之後的操作失效!
commit and chain 結束一個事務開啟另一個事務
rollback and release 回滾之後斷開客戶端的連線