程序員之MySQL

1.MySQL解決幻讀問題

MySQL InnoDB通過版本號解決事務(wù)的幻讀問題
a.select情況:
InnoDB只會查找版本高于當(dāng)前事務(wù)版本的數(shù)據(jù)行(即行的系統(tǒng)版本小于或等于事務(wù)的系統(tǒng)版本號)竭钝,這樣確保了事務(wù)讀取的行是當(dāng)前事務(wù)開始之前已經(jīng)存在的行,或者是事務(wù)自己自身插入或者修改的行。

b.insert情況:
InnoDB為新插入的每一行記錄保存當(dāng)前系統(tǒng)的版本號作為行版本號兆解。

c.delete情況:
InnoDB為刪除的每一行記錄保存當(dāng)前系統(tǒng)的版本號作為行刪除標(biāo)示蛛砰。

d.update情況:
InnoDB為新插入的每一行記錄保存當(dāng)前系統(tǒng)的版本號作為行版本號散庶,同時保存當(dāng)前系統(tǒng)版本號到原來的行作為行刪除標(biāo)示抛蚤。

2.MySQL不走索引的情況

1.使用like '%abc'宝冕;
2.where 中的or不是所有字段都是索引字段旧蛾;
3.組合索引莽龟,不包含第一個字段的查詢;
4.子查詢中order by的索引會失效锨天,同時可能導(dǎo)致子查詢中的where條件索引都不能用毯盈;
5.列類型為字符串類型,查詢時沒有用單引號引起來病袄;
6.在where查詢語句中使用表達(dá)式或者函數(shù)搂赋;
7.在where查詢語句中對字段進(jìn)行NULL值判斷;
8.DATE_FORMAT()格式化時間益缠,格式化后的時間再去比較脑奠,可能會導(dǎo)致索引失效。

3.B+樹的優(yōu)點(diǎn)

1.從根節(jié)點(diǎn)到葉子節(jié)點(diǎn)的搜索效率基本相同幅慌,不會出現(xiàn)大幅波動宋欺;
2.方便順序掃描,只需要遍歷所有葉子節(jié)點(diǎn)即可;
3.磁盤讀寫代價低齿诞,因?yàn)榉侨~子節(jié)點(diǎn)不保存行數(shù)據(jù)酸休,同一個數(shù)據(jù)塊,非葉子節(jié)點(diǎn)保存的關(guān)鍵字?jǐn)?shù)據(jù)量比B樹要高很多祷杈,因此一次讀入的關(guān)鍵字也就越多斑司,降低了IO次數(shù);
4.B+樹支持范圍查詢吠式,而B樹對范圍查詢支持性很差陡厘。

4.MySQL自增主鍵

優(yōu)點(diǎn):
1.插入效率高,每次插入新的記錄特占,記錄會順序的添加到當(dāng)前索引節(jié)點(diǎn)的后續(xù)位置糙置,當(dāng)前頁寫滿后,自動開辟新的一頁是目;
2.節(jié)省索引存儲空間谤饭,技術(shù)是UUID的兩倍;
3.使用UUID(Universally Unique Identifier)主鍵的時候懊纳,每次插入主鍵時揉抵,插入的索引中的位置幾乎隨機(jī),會導(dǎo)致非葉子節(jié)點(diǎn)的分裂嗤疯,MySQL不得不為了插入新紀(jì)錄而移動數(shù)據(jù)冤今,,甚至導(dǎo)致磁盤IO和不飽和的節(jié)點(diǎn)茂缚,造成大量的碎片戏罢,甚至觸發(fā)optimize table重建表來優(yōu)化。

缺點(diǎn):
1.不適合分表脚囊、分庫和分布式的場景龟糕。這些場景只能犧牲性能,使用UUID悔耘,但是UUID適合小規(guī)模的分布式環(huán)境讲岁,不適合大規(guī)模的分布式環(huán)境,特別數(shù)據(jù)量大時衬以,UUID帶來的讀寫性能的下降很厲害缓艳。

Twitter為解決分布式自增ID的問題,給出了snowflake雪花算法來實(shí)現(xiàn)全局自增ID泄鹏,這樣ID的生成不依賴于DB郎任,而是依賴于內(nèi)存,高性能高可用备籽。但是snowflake算法依賴于系統(tǒng)時鐘的一致性,如果機(jī)器的時鐘回?fù)埽赡軙?dǎo)致ID沖突车猬。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末霉猛,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子珠闰,更是在濱河造成了極大的恐慌惜浅,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件伏嗜,死亡現(xiàn)場離奇詭異坛悉,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)承绸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門裸影,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人军熏,你說我怎么就攤上這事轩猩。” “怎么了荡澎?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵均践,是天一觀的道長。 經(jīng)常有香客問我摩幔,道長彤委,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任或衡,我火速辦了婚禮焦影,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘薇宠。我一直安慰自己偷办,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布澄港。 她就那樣靜靜地躺著椒涯,像睡著了一般。 火紅的嫁衣襯著肌膚如雪回梧。 梳的紋絲不亂的頭發(fā)上废岂,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機(jī)與錄音狱意,去河邊找鬼湖苞。 笑死,一個胖子當(dāng)著我的面吹牛详囤,可吹牛的內(nèi)容都是我干的财骨。 我是一名探鬼主播镐作,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼隆箩!你這毒婦竟也來了该贾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤捌臊,失蹤者是張志新(化名)和其女友劉穎杨蛋,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體理澎,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡逞力,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了糠爬。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片寇荧。...
    茶點(diǎn)故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖秩铆,靈堂內(nèi)的尸體忽然破棺而出砚亭,到底是詐尸還是另有隱情,我是刑警寧澤殴玛,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布捅膘,位于F島的核電站,受9級特大地震影響滚粟,放射性物質(zhì)發(fā)生泄漏寻仗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一凡壤、第九天 我趴在偏房一處隱蔽的房頂上張望署尤。 院中可真熱鬧,春花似錦亚侠、人聲如沸曹体。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽箕别。三九已至,卻和暖如春滞谢,著一層夾襖步出監(jiān)牢的瞬間串稀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工狮杨, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留母截,地道東北人。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓橄教,卻偏偏與公主長得像清寇,于是被迫代替她去往敵國和親喘漏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評論 2 354