久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

阿里P8架構(gòu)師談:MySQL有哪些存儲(chǔ)引擎,各自的優(yōu)缺點(diǎn),,應(yīng)用場(chǎng)景

 印度阿三17 2020-05-06

經(jīng)常面試都會(huì)問(wèn)到MYSQL有哪些存儲(chǔ)引擎,,以及各自的優(yōu)缺點(diǎn),。今天主要分享常見(jiàn)的存儲(chǔ)引擎:MyISAM、InnoDB,、MERGE,、MEMORY(HEAP)、BDB(BerkeleyDB)等,,以及最常用的MyISAM與InnoDB兩個(gè)引擎 ,,文章尾部有兩者的詳細(xì)比較。

MySQL常用存儲(chǔ)引擎介紹

1.InnoDB 引擎(MySQL5.5以后默認(rèn)使用)

MySQL 5.5 及以后版本中的默認(rèn)存儲(chǔ)引擎,,他的優(yōu)點(diǎn)如下:

  • 災(zāi)難恢復(fù)性好

  • 支持事務(wù)

  • 使用行級(jí)鎖

  • 支持外鍵關(guān)聯(lián)

  • 支持熱備份

  • 對(duì)于InnoDB引擎中的表,,其數(shù)據(jù)的物理組織形式是簇表(Cluster Table),主鍵索引和數(shù)據(jù)是在一起的,,數(shù)據(jù)按主鍵的順序物理分布

  • 實(shí)現(xiàn)了緩沖管理,,不僅能緩沖索引也能緩沖數(shù)據(jù),并且會(huì)自動(dòng)創(chuàng)建散列索引以加快數(shù)據(jù)的獲取

  • 支持熱備份

2.MyISAM引擎

特性如下:

  • 不支持事務(wù)

  • 使用表級(jí)鎖,,并發(fā)性差

  • 主機(jī)宕機(jī)后,,MyISAM表易損壞,災(zāi)難恢復(fù)性不佳

  • 可以配合鎖,,實(shí)現(xiàn)操作系統(tǒng)下的復(fù)制備份,、遷移

  • 只緩存索引,數(shù)據(jù)的緩存是利用操作系統(tǒng)緩沖區(qū)來(lái)實(shí)現(xiàn)的,??赡芤l(fā)過(guò)多的系統(tǒng)調(diào)用且效率不佳

  • 數(shù)據(jù)緊湊存儲(chǔ),因此可獲得更小的索引和更快的全表掃描性能

3.MEMORY 存儲(chǔ)引擎

提供內(nèi)存表,,也不支持事務(wù)和外鍵。顯著提高訪問(wèn)數(shù)據(jù)的速度,,可用于緩存會(huì)頻繁訪問(wèn)的,、可以重構(gòu)的數(shù)據(jù)、計(jì)算結(jié)果,、統(tǒng)計(jì)值,、中間結(jié)果。

缺點(diǎn)如下:

  • 使用表級(jí)鎖,,雖然內(nèi)存訪問(wèn)快,,但如果頻繁的讀寫,表級(jí)鎖會(huì)成為瓶頸

  • 只支持固定大小的行,。Varchar類型的字段會(huì)存儲(chǔ)為固定長(zhǎng)度的Char類型,,浪費(fèi)空間

  • 不支持TEXT、BLOB字段,。當(dāng)有些查詢需要使用到臨時(shí)表(使用的也是MEMORY存儲(chǔ)引擎)時(shí),,如果表中有TEXT,、BLOB字段,那么會(huì)轉(zhuǎn)換為基于磁盤的MyISAM表,,嚴(yán)重降低性能

  • 由于內(nèi)存資源成本昂貴,,一般不建議設(shè)置過(guò)大的內(nèi)存表,如果內(nèi)存表滿了,,可通過(guò)清除數(shù)據(jù)或調(diào)整內(nèi)存表參數(shù)來(lái)避免報(bào)錯(cuò)

  • 服務(wù)器重啟后數(shù)據(jù)會(huì)丟失,,復(fù)制維護(hù)時(shí)需要小心

MySQL存儲(chǔ)引擎MyISAM與InnoDB如何選擇

1.兩種存儲(chǔ)引擎的大致區(qū)別表現(xiàn)在:

1)InnoDB支持事務(wù),MyISAM不支持,,這一點(diǎn)是非常之重要,。事務(wù)是一種高級(jí)的處理方式,如在一些列增刪改中只要哪個(gè)出錯(cuò)還可以回滾還原,,而MyISAM就不可以了,。

2)MyISAM適合查詢以及插入為主的應(yīng)用,InnoDB適合頻繁修改以及涉及到安全性較高的應(yīng)用

3)InnoDB支持外鍵,,MyISAM不支持

4)從MySQL5.5.5以后,,InnoDB是默認(rèn)引擎

5)InnoDB不支持FULLTEXT類型的索引

6)InnoDB中不保存表的行數(shù),如select count(*) from table時(shí),,InnoDB需要掃描一遍整個(gè)表來(lái)計(jì)算有多少行,,但是MyISAM只要簡(jiǎn)單的讀出保存好的行數(shù)即可。注意的是,,當(dāng)count(*)語(yǔ)句包含where條件時(shí)MyISAM也需要掃描整個(gè)表,。

7)對(duì)于自增長(zhǎng)的字段,InnoDB中必須包含只有該字段的索引,,但是在MyISAM表中可以和其他字段一起建立聯(lián)合索引,。

8)清空整個(gè)表時(shí),InnoDB是一行一行的刪除,,效率非常慢,。MyISAM則會(huì)重建表。

9)InnoDB支持行鎖(某些情況下還是鎖整表,,如 update table set a=1 where user like ‘%lee%’

有人說(shuō)MYISAM只能用于小型應(yīng)用,,其實(shí)這只是一種偏見(jiàn)。

如果數(shù)據(jù)量比較大,,這是需要通過(guò)升級(jí)架構(gòu)來(lái)解決,,比如分表分庫(kù),讀寫分離,,而不是單純地依賴存儲(chǔ)引擎,。

現(xiàn)在一般都是選用InnoDB了,主要是MyISAM的全表鎖,讀寫串行問(wèn)題,,并發(fā)效率鎖表,,效率低,MyISAM對(duì)于讀寫密集型應(yīng)用一般是不會(huì)去選用的,。

總之:

1.MyISAM類型不支持事務(wù)處理等高級(jí)處理,,而InnoDB類型支持。

2.MyISAM類型的表強(qiáng)調(diào)的是性能,,其執(zhí)行速度比InnoDB類型更快,,但是不提供事務(wù)支持,而InnoDB提供事務(wù)支持已經(jīng)外部鍵等高級(jí)數(shù)據(jù)庫(kù)功能,。


來(lái)源:https://www./content-2-689551.html

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn),。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多