這篇文章主要講解了“怎么理解mysql特性semi consistent read”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“怎么理解mysql特性semi consistent read”吧!
我們擁有十余年網(wǎng)頁(yè)設(shè)計(jì)和網(wǎng)站建設(shè)經(jīng)驗(yàn),從網(wǎng)站策劃到網(wǎng)站制作,我們的網(wǎng)頁(yè)設(shè)計(jì)師為您提供的解決方案。為企業(yè)提供網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、微信開(kāi)發(fā)、微信小程序、移動(dòng)網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)、等業(yè)務(wù)。無(wú)論您有什么樣的網(wǎng)站設(shè)計(jì)或者設(shè)計(jì)方案要求,我們都將富于創(chuàng)造性的提供專(zhuān)業(yè)設(shè)計(jì)服務(wù)并滿(mǎn)足您的需求。先看看官方的說(shuō)法:
semi consistent read
A type of read operation used for UPDATE statements, that is a combination of read committed and consistent read. When an UPDATE statement examines a row that is already locked, InnoDB returns the latest committed version to MySQL so that MySQL can determine whether the row matches the WHERE condition of the UPDATE. If the row matches (must be updated), MySQL reads the row again, and this time InnoDB either locks it or waits for a lock on it. This type of read operation can only happen when the transaction has the read committed isolation level, or when the innodb_locks_unsafe_for_binlog option is enabled.
簡(jiǎn)單來(lái)說(shuō),semi-consistent read是read committed與consistent read兩者的結(jié)合。一個(gè)update語(yǔ)句,如果讀到一行已經(jīng)加鎖的記錄,此時(shí)InnoDB返回記錄最近提交的版本,由MySQL上層判斷此版本是否滿(mǎn)足update的where條件。若滿(mǎn)足(需要更新),則MySQL會(huì)重新發(fā)起一次讀操作,此時(shí)會(huì)讀取行的最新版本(并加鎖)。
semi-consistent read只會(huì)發(fā)生在read committed隔離級(jí)別或以下,或者是參數(shù)innodb_locks_unsafe_for_binlog被設(shè)置為true。
semi consistent read作用情形:
1、RC、RU模式下,或者 innodb_locks_unsafe_for_binlog = 1
2、先執(zhí)行非UPDATE SQL,后執(zhí)行UPDATE,不會(huì)阻塞。如果先執(zhí)行UPDATE,后執(zhí)行其他非UPDATE SQL,則還是會(huì)加鎖
3、只影響有實(shí)際存在的行,不存在的行也OK
我的理解:
在rc級(jí)別或以下級(jí)別(ru),或者 innodb_locks_unsafe_for_binlog = 1(RR) 這三種情況下,會(huì)發(fā)生semi_consistent_read.
因?yàn)閕nnodb是行級(jí)鎖,如果字段沒(méi)有索引,在加鎖時(shí),會(huì)上升為表鎖.此時(shí),如果s1執(zhí)行加鎖任何操作,s2執(zhí)行update操作,在s2的update條件中如果在s1中沒(méi)有行鎖,將不會(huì)堵塞s2.原理是:s2發(fā)起的update,有mysql上層根據(jù)update條件判斷是否滿(mǎn)足,若條件中沒(méi)有行鎖,則mysql會(huì)重新發(fā)起一次讀操作,并在update后加鎖;
同理:如果列是有索引存在的.innodb會(huì)自動(dòng)產(chǎn)生的是行鎖,所以semi_consistent_read的效能也就沒(méi)有什么意義..
所以.semi_consistent_read只發(fā)生在沒(méi)有索引的列,或者有全表鎖的情況;只要存在update的數(shù)據(jù)上有行鎖的,semi_consistent_read就失效;
感謝各位的閱讀,以上就是“怎么理解mysql特性semi consistent read”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)怎么理解mysql特性semi consistent read這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!