国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 為什么一個(gè)事務(wù)能讀取到其他事務(wù)修改后未提交的數(shù)據(jù)?

為什么一個(gè)事務(wù)能讀取到其他事務(wù)修改后未提交的數(shù)據(jù)?

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-10-13 01:25:09 1697131509

一、為什么一個(gè)事務(wù)能讀取到其他事務(wù)修改后未提交的數(shù)據(jù)

在沒(méi)有正式提交之前,數(shù)據(jù)是先更新到日志之中的,只有commit提交之后,才真正再?gòu)娜罩局懈碌絤ysql表中。你不用去糾結(jié)為什么能讀到它。你只需知道,是事務(wù)與事務(wù)并發(fā)進(jìn)行時(shí),是具有影響性的,這種影響性的大小被稱為隔離級(jí)別。那怎么防止未提交讀呢?就是加寫(xiě)鎖,然后提交之后釋放鎖,在這個(gè)時(shí)候,mysql的隔離級(jí)別就變成了已提交讀。而加鎖,釋放鎖是由mysql自動(dòng)完成的,你無(wú)需關(guān)心。所以,其實(shí)本質(zhì)上是鎖的應(yīng)用,最終導(dǎo)致了不同的隔離級(jí)別,不同的隔離級(jí)別,鎖的應(yīng)用也不同。

“數(shù)據(jù)未提交,那數(shù)據(jù)庫(kù)應(yīng)該沒(méi)有改變”,這個(gè)假設(shè)其實(shí)是錯(cuò)誤的。數(shù)據(jù)庫(kù)的底層設(shè)計(jì)都使用了WAL(Write-ahead**Logging)思想,只不過(guò)數(shù)據(jù)庫(kù)的事務(wù)隔離技術(shù)了提供了各種方案,一個(gè)數(shù)據(jù)庫(kù)請(qǐng)求即使事務(wù)沒(méi)有提交也會(huì)發(fā)生數(shù)據(jù)庫(kù)內(nèi)部數(shù)據(jù)的變更,有各種技術(shù),像Mysql InnoDB MVCC,只不過(guò)是通過(guò)一些字段進(jìn)行控制。

在數(shù)據(jù)庫(kù)沒(méi)有提交數(shù)據(jù)的時(shí)候,你更新的數(shù)據(jù)是在緩存進(jìn)行更新的,事務(wù)與事務(wù)在并發(fā)進(jìn)行的時(shí)候就叫作隔離級(jí)別,只有在提交之后,數(shù)據(jù)才從日志中把數(shù)據(jù)更新到數(shù)據(jù)庫(kù)里面。

目前主流的關(guān)系型數(shù)據(jù)庫(kù)例如mysql、Oracle都是基于文件系統(tǒng)進(jìn)行數(shù)據(jù)存儲(chǔ)的,即數(shù)據(jù)是持久化到文件系統(tǒng)的,但基于文件系統(tǒng)的隨機(jī)IO讀寫(xiě)是非常慢的,故數(shù)據(jù)庫(kù)都會(huì)引入內(nèi)存池,完成對(duì)磁盤(pán)數(shù)據(jù)的緩存,提高讀寫(xiě)性能。內(nèi)存池是對(duì)所有線程共享的,也就是對(duì)所有的數(shù)據(jù)庫(kù)事務(wù)是共享的,所謂的未提交,指的是事務(wù)未提交,但此時(shí)數(shù)據(jù)已經(jīng)存儲(chǔ)到了共享內(nèi)存中,數(shù)據(jù)已經(jīng)進(jìn)入到了數(shù)據(jù)庫(kù)服務(wù)器中,所以是可見(jiàn)的。

延伸閱讀:

二、MongoDB是什么

非關(guān)系型數(shù)據(jù)庫(kù)(nosql ),屬于文檔型數(shù)據(jù)庫(kù)。MongoDB采用類JSON的documents來(lái)存儲(chǔ)數(shù)據(jù)。數(shù)據(jù)結(jié)構(gòu)由鍵值(key=>value)對(duì)組成。

MongoDB采用動(dòng)態(tài)數(shù)據(jù)模型schema,這意味著不需要預(yù)先定義表的數(shù)據(jù)類型和字段名。當(dāng)MongoDB需要更新文檔documents的時(shí)候,可以輕松增加新的字段名或者刪除舊的字段。MongoDB讓數(shù)據(jù)結(jié)構(gòu)更加層級(jí)化,因而存儲(chǔ)數(shù)組等復(fù)雜數(shù)據(jù)結(jié)構(gòu)。 在同一個(gè)集合collection中,文檔document對(duì)字段也沒(méi)有強(qiáng)約束,因此更容易設(shè)計(jì)差異化的數(shù)據(jù)結(jié)構(gòu)。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
InnoDB的意向鎖有什么作用?

一、InnoDB的意向鎖的作用1、鎖沖突優(yōu)化意向鎖提供了一種機(jī)制,讓事務(wù)可以事先聲明它將在某個(gè)級(jí)別對(duì)數(shù)據(jù)行進(jìn)行鎖定。這樣其他事務(wù)可以更快速地...詳情>>

2023-10-13 03:08:17
文件系統(tǒng)和數(shù)據(jù)庫(kù)是由于什么原因才選擇B樹(shù)或B+樹(shù)建立?

一、文件系統(tǒng)和數(shù)據(jù)庫(kù)是由于什么原因才選擇B樹(shù)或B+樹(shù)建立索引的索引的目標(biāo)是要找到數(shù)據(jù)所在的物理位置,因此用樹(shù)去實(shí)現(xiàn)搜索數(shù)據(jù)所在物理位置,...詳情>>

2023-10-13 03:03:02
系統(tǒng)運(yùn)維、IT運(yùn)維、網(wǎng)絡(luò)運(yùn)維、數(shù)據(jù)庫(kù)運(yùn)維有哪些區(qū)別?

一、系統(tǒng)運(yùn)維、IT運(yùn)維、網(wǎng)絡(luò)運(yùn)維、數(shù)據(jù)庫(kù)運(yùn)維區(qū)別網(wǎng)絡(luò)運(yùn)維,數(shù)據(jù)庫(kù)運(yùn)維,Linux運(yùn)維,window運(yùn)維,桌面運(yùn)維,根底架構(gòu)運(yùn)維,信息體系運(yùn)維,ERP體...詳情>>

2023-10-13 02:58:27
QQ數(shù)據(jù)庫(kù)是怎樣設(shè)計(jì)的?

一、QQ數(shù)據(jù)庫(kù)是怎樣設(shè)計(jì)的1、對(duì)于群成員上限的問(wèn)題,不是從數(shù)據(jù)庫(kù)層面解決的,而應(yīng)該有專門(mén)的“配額檢查”服務(wù)/邏輯,在群成員人數(shù)變化時(shí)用來(lái)判...詳情>>

2023-10-13 02:36:05
RESTful API的命名有什么講究?

一、RESTful API的命名有什么講究和目錄沒(méi)關(guān)系,通常是框架路由接管的 request uri解析出來(lái)的(v1、v2有可能是實(shí)際的目錄)restful規(guī)范/資源名/...詳情>>

2023-10-13 02:32:10
快速通道