10.MYSQL:什么是事务?事务的性质?事务的应用?
所謂事務(wù),其實就是相當(dāng)于操作系統(tǒng)里的原子性操作。它將一組對于數(shù)據(jù)庫表的操作綁定在一起,只有所有操作都成功,才提交,只要有一個操作失敗的話,那么就不會提交。這樣的機制保證了數(shù)據(jù)庫數(shù)據(jù)的原子性、一致性、隔離性以及持久性。
?所謂ACID即是上面提到的原子性、一致性、隔離性以及持久性。
原子性:事務(wù)被視為不可分割的最小單元。事務(wù)的所有操作要么全部提交成功,要么全部失敗回滾。
一致性:數(shù)據(jù)庫在事務(wù)執(zhí)行前后保持一致性的狀態(tài)。在一致性的狀態(tài)之下,所有事務(wù)對一個數(shù)據(jù)的讀取狀態(tài)都是相同。?
?隔離性:一個事務(wù)所做的修改,在提交之前,對其他的事務(wù)是不可見的。
持久性:一旦事務(wù)提交之后,其所做的修改將永久的保存在數(shù)據(jù)庫中。即使系統(tǒng)發(fā)生崩潰,事務(wù)執(zhí)行的結(jié)果也不能丟失。
首先還得明確,只有存儲引擎為INNODB的MYSQL數(shù)據(jù)庫這才支持事務(wù)!
要掌握事務(wù)機制,我們需要以下幾個知識點:
1)對于表的增刪改查的提交方式?
在MYSQL中,表的默認(rèn)提交方式是自動提交(也即默認(rèn):autocommit=1),也就是對于表的操作是即時生效的。
可以通過set autocommit = 0; 修改為手動顯示提交!顯示提交的語句為 commit
2)事務(wù)如何開啟?
在MYSQL中,事務(wù)通過語句?? start transaction 開啟!他等價于? set autocommit = 0。兩者寫一個就行了。
還有,在INNODB的鎖機制中,?start transaction 等價于 unlock 解鎖操作
3)事務(wù)如何回滾?
記住!事務(wù)只支持 UPDATE/DELETE/INSERT語句的回滾,不支持SELECT/DROP/CREATE的回滾,但是事務(wù)處理塊中可以使用這幾條語句(SELECT/DROP/CREATE)。
rollback語句實現(xiàn)事務(wù)的回滾。默認(rèn)情況下,回退到事務(wù)操作之前!在設(shè)置了保存點之后,可回滾到相應(yīng)的保存點處!
4)如何設(shè)置保存點?如何根據(jù)設(shè)置的保存點進行回滾操作?
在每條操作之后添加語句?? savepoint 保存點名稱? 即設(shè)置了對應(yīng)操作的保存點!
通過 rollback to 保存點名稱?可以回滾到相應(yīng)的保存點,不過記住回滾點之前的操作都是生效的,回滾點之后的操作失效!
commit and chain? 結(jié)束一個事務(wù)開啟另一個事務(wù)
rollback and release? 回滾之后斷開客戶端的連接
在無并發(fā)的情況之下,事務(wù)串行進行,隔離性一定能夠滿足!只要再滿足原子性,就一定能夠滿足一致性!
在并發(fā)的情況之下,事務(wù)并行執(zhí)行,除了要滿足原子性,還要滿足隔離性,事務(wù)的一致性才能滿足!
事務(wù)做持久化是為了應(yīng)對數(shù)據(jù)庫崩潰的情況。
?
?
總結(jié)
以上是生活随笔為你收集整理的10.MYSQL:什么是事务?事务的性质?事务的应用?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 9.MYSQL:MyISAM表级锁(共享
- 下一篇: 24.指针和引用的区别