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