1. 程式人生 > >10.MYSQL:什麼是事務?事務的應用?

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  回滾之後斷開客戶端的連線