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

歡迎訪問 生活随笔!

生活随笔

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

数据库

阿里P8架构师谈:MySQL有哪些存储引擎,各自的优缺点,应用场景

發(fā)布時(shí)間:2024/7/5 数据库 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 阿里P8架构师谈:MySQL有哪些存储引擎,各自的优缺点,应用场景 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

經(jīng)常面試都會(huì)問到MYSQL有哪些存儲(chǔ)引擎,以及各自的優(yōu)缺點(diǎ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ù)
  • 使用行級鎖
  • 支持外鍵關(guān)聯(lián)
  • 支持熱備份
  • 對于InnoDB引擎中的表,其數(shù)據(jù)的物理組織形式是簇表(Cluster Table),主鍵索引和數(shù)據(jù)是在一起的,數(shù)據(jù)按主鍵的順序物理分布
  • 實(shí)現(xiàn)了緩沖管理,不僅能緩沖索引也能緩沖數(shù)據(jù),并且會(huì)自動(dòng)創(chuàng)建散列索引以加快數(shù)據(jù)的獲取
  • 支持熱備份

2.MyISAM引擎

特性如下:

  • 不支持事務(wù)
  • 使用表級鎖,并發(fā)性差
  • 主機(jī)宕機(jī)后,MyISAM表易損壞,災(zāi)難恢復(fù)性不佳
  • 可以配合鎖,實(shí)現(xiàn)操作系統(tǒng)下的復(fù)制備份、遷移
  • 只緩存索引,數(shù)據(jù)的緩存是利用操作系統(tǒng)緩沖區(qū)來實(shí)現(xiàn)的。可能引發(fā)過多的系統(tǒng)調(diào)用且效率不佳
  • 數(shù)據(jù)緊湊存儲(chǔ),因此可獲得更小的索引和更快的全表掃描性能

3.MEMORY 存儲(chǔ)引擎

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

缺點(diǎn)如下:

  • 使用表級鎖,雖然內(nèi)存訪問快,但如果頻繁的讀寫,表級鎖會(huì)成為瓶頸
  • 只支持固定大小的行。Varchar類型的字段會(huì)存儲(chǔ)為固定長度的Char類型,浪費(fèi)空間
  • 不支持TEXT、BLOB字段。當(dāng)有些查詢需要使用到臨時(shí)表(使用的也是MEMORY存儲(chǔ)引擎)時(shí),如果表中有TEXT、BLOB字段,那么會(huì)轉(zhuǎn)換為基于磁盤的MyISAM表,嚴(yán)重降低性能
  • 由于內(nèi)存資源成本昂貴,一般不建議設(shè)置過大的內(nèi)存表,如果內(nèi)存表滿了,可通過清除數(shù)據(jù)或調(diào)整內(nèi)存表參數(shù)來避免報(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ù)是一種高級的處理方式,如在一些列增刪改中只要哪個(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è)表來計(jì)算有多少行,但是MyISAM只要簡單的讀出保存好的行數(shù)即可。注意的是,當(dāng)count(*)語句包含where條件時(shí)MyISAM也需要掃描整個(gè)表。

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

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

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

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

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

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

總之:

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

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

如果你還想了解mysql的各種鎖:表鎖、行鎖、樂觀鎖等,可以點(diǎn)擊查看:

阿里P8架構(gòu)師談:MySQL行鎖、表鎖、悲觀鎖、樂觀鎖的特點(diǎn)與應(yīng)用

你可能也喜歡:

  • 阿里P8架構(gòu)師談:MongoDB、Hbase、Redis等NoSQL優(yōu)劣勢、應(yīng)用場景
  • 阿里P8架構(gòu)師談:MySQL行鎖、表鎖、悲觀鎖、樂觀鎖的特點(diǎn)與應(yīng)用
  • 阿里P8架構(gòu)師談:MySQL數(shù)據(jù)庫的索引原理、與慢SQL優(yōu)化的5大原則
  • 阿里P8架構(gòu)師談:MySQL慢查詢優(yōu)化、索引優(yōu)化、以及表等優(yōu)化總結(jié)
  • 去騰訊等BAT面試完的Mysql面試55題總結(jié),含答案大贈(zèng)送!
  • 最全MySQL面試60題和答案

  • 總結(jié)

    以上是生活随笔為你收集整理的阿里P8架构师谈:MySQL有哪些存储引擎,各自的优缺点,应用场景的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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