日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

10.MYSQL:什么是事务?事务的性质?事务的应用?

發(fā)布時間:2025/3/21 数据库 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 10.MYSQL:什么是事务?事务的性质?事务的应用? 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

所謂事務(wù),其實就是相當(dāng)于操作系統(tǒng)里的原子性操作它將一組對于數(shù)據(jù)庫表的操作綁定在一起,只有所有操作都成功,才提交,只要有一個操作失敗的話,那么就不會提交。這樣的機(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ù)機(jī)制,我們需要以下幾個知識點:

1)對于表的增刪改查的提交方式?

在MYSQL中,表的默認(rèn)提交方式是自動提交(也即默認(rèn):autocommit=1),也就是對于表的操作是即時生效的。

可以通過set autocommit = 0; 修改為手動顯示提交!顯示提交的語句為 commit

2)事務(wù)如何開啟?

在MYSQL中,事務(wù)通過語句?? start transaction 開啟!他等價于? set autocommit = 0。兩者寫一個就行了。

還有,在INNODB的鎖機(jī)制中,?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è)置的保存點進(jìn)行回滾操作?

在每條操作之后添加語句?? savepoint 保存點名稱? 即設(shè)置了對應(yīng)操作的保存點!

通過 rollback to 保存點名稱?可以回滾到相應(yīng)的保存點不過記住回滾點之前的操作都是生效的,回滾點之后的操作失效!


commit and chain? 結(jié)束一個事務(wù)開啟另一個事務(wù)

rollback and release? 回滾之后斷開客戶端的連接


在無并發(fā)的情況之下,事務(wù)串行進(jìn)行,隔離性一定能夠滿足!只要再滿足原子性,就一定能夠滿足一致性!

在并發(fā)的情況之下,事務(wù)并行執(zhí)行,除了要滿足原子性,還要滿足隔離性,事務(wù)的一致性才能滿足!

事務(wù)做持久化是為了應(yīng)對數(shù)據(jù)庫崩潰的情況。

?

?

總結(jié)

以上是生活随笔為你收集整理的10.MYSQL:什么是事务?事务的性质?事务的应用?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。