一区二区三区中文国产亚洲_另类视频区第一页_日韩精品免费视频_女人免费视频_国产综合精品久久亚洲

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

手機站
千鋒教育

千鋒學(xué)習站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

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

關(guān)注千鋒學(xué)習站小程序
隨時隨地免費學(xué)習課程

當前位置:首頁  >  技術(shù)干貨  > 什么是存儲引擎

什么是存儲引擎

來源:千鋒教育
發(fā)布人:yyy
時間: 2023-06-28 14:28:00 1687933680

  

  1.什么是存儲引擎

數(shù)據(jù)庫最核心的一點就是用來存儲數(shù)據(jù),數(shù)據(jù)存儲就避免不了和磁盤打交道。那么數(shù)據(jù)以哪種方式進行存儲,如何存儲是存儲的關(guān)鍵所在。所以存儲引擎就相當于是數(shù)據(jù)存儲的發(fā)動機,來驅(qū)動數(shù)據(jù)在磁盤層面進行存儲。不同的存儲引擎功能差別很大。

  2.InnoDB存儲引擎

什么是存儲引擎

  特點:

  ● InnoDB存儲引擎提供了具有提交、回滾和崩潰恢復(fù)能力的事務(wù)安全。相比較MyISAM存儲引擎,InnoDB寫的處理效率差一點并且會占用更多的磁盤空間保留數(shù)據(jù)和索引。

  ● 提供了對數(shù)據(jù)庫事務(wù)ACID(原子性Atomicity、一致性Consistency、隔離性Isolation、持久性Durability)的支持,實現(xiàn)了SQL標準的四種隔離級別。

  ● 設(shè)計目標就是處理大容量的數(shù)據(jù)庫系統(tǒng),MySQL運行時InnoDB會在內(nèi)存中建立緩沖池,用于緩沖數(shù)據(jù)和索引。

  ● 執(zhí)行“select count(*) from table”語句時需要掃描全表,因為使用innodb引擎的表不會保存表的具體行數(shù),所以需要掃描整個表才能計算多少行。

  ● InnoDB引擎是行鎖,粒度更小,所以寫操作不會鎖定全表,在并發(fā)較高時,使用InnoDB會提升效率。即存在大量UPDATE/INSERT操作時,效率較高。

  ● InnoDB清空數(shù)據(jù)量大的表時,是非常緩慢,這是因為InnoDB必須處理表中的每一行,根據(jù)InnoDB的事務(wù)設(shè)計原則,首先需要把“刪除動作”寫入“事務(wù)日志”,然后寫入實際的表。所以,清空大表的時候,最好直接drop table然后重建。即InnoDB一行一行刪除,不會重建表。

  使用場景:

  ● 經(jīng)常UPDETE/INSERT的表,使用處理多并發(fā)的寫請求。

  ● 支持事務(wù),必選InnoDB。

  ● 可以從災(zāi)難中恢復(fù)(日志+事務(wù)回滾)。

  ● 外鍵約束、列屬性AUTO_INCREMENT支持。

  3.MyISAM存儲引擎

  特點:

  ● MyISAM不支持事務(wù),不支持外鍵,SELECT/INSERT為主的應(yīng)用可以使用該引擎。

  ● 每個MyISAM在存儲成3個文件,擴展名分別是:

  ○ frm:存儲表定義(表結(jié)構(gòu)等信息)。

  ○ MYD(MYData),存儲數(shù)據(jù)。

  ○ MYI(MYIndex),存儲索引。

  ● 不同MyISAM表的索引文件和數(shù)據(jù)文件可以放置到不同的路徑下。

  ● MyISAM類型的表提供修復(fù)的工具,可以用CHECK TABLE語句來檢查MyISAM表健康,并用REPAIR TABLE語句修復(fù)一個損壞的MyISAM表。

  ● 在MySQL5.6以前,只有MyISAM支持Full-text全文索引。

  使用場景:

  ● 經(jīng)常SELECT/INSERT的表,插入不頻繁,查詢非常頻繁。

  ● 不支持事務(wù)。

  ● 做很多count 的計算。

什么是存儲引擎

  4.MyISAM和Innodb區(qū)別

  InnoDB和MyISAM是許多人在使用MySQL時最常用的兩個存儲引擎,這兩個存儲引擎各有優(yōu)劣,視具體應(yīng)用而定?;镜牟顒e為:MyISAM類型不支持事務(wù)處理,而InnoDB類型支持。MyISAM類型強調(diào)的是性能,其執(zhí)行速度比InnoDB類型更快,而InnoDB提供事務(wù)支持已經(jīng)外部鍵等高級數(shù)據(jù)庫功能。

  具體實現(xiàn)的差別:

  ● MyISAM是非事務(wù)安全型的,而InnoDB是事務(wù)安全型的。

  ● MyISAM鎖的粒度是表級,而InnoDB支持行級鎖定。

  ● MyISAM不支持外鍵,而InnoDB支持外鍵。

  ● MyISAM相對簡單,所以在效率上要優(yōu)于InnoDB,小型應(yīng)用可以考慮使用MyISAM。

  ● InnoDB表比MyISAM表更安全。

tags: 存儲引擎
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習老師24小時內(nèi)將與您1V1溝通
免費領(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
graph cut和graph cuts有什么區(qū)別?

1.語境不同graph cut”通常在描述一個操作時使用,比如”perform a graph cut”,它指的是在圖中找到一個切割,將圖劃分為兩個...詳情>>

2023-10-15 07:02:16
什么是雙機熱備?

一、雙機熱備的原理雙機熱備是指在系統(tǒng)中配置兩臺服務(wù)器(主服務(wù)器和備份服務(wù)器),兩者通過高速網(wǎng)絡(luò)連接進行實時數(shù)據(jù)同步和狀態(tài)同步。主服務(wù)器...詳情>>

2023-10-15 06:37:02
偏最小二乘支持向量機和支持向量機回歸的區(qū)別是什么?

1.模型構(gòu)建的理論基礎(chǔ)不同支持向量機回歸(SVR)基于統(tǒng)計學(xué)習理論,其主要思想是找到一個超平面,使得大部分數(shù)據(jù)點都在這個超平面的一定范圍內(nèi),...詳情>>

2023-10-15 06:30:45
VAE、GAN和transformer有什么區(qū)別?

1.模型結(jié)構(gòu)不同VAE(變分自編碼器)是一種生成模型,其基于概率圖模型和自編碼器,能夠?qū)W習數(shù)據(jù)的潛在分布。GAN(生成對抗網(wǎng)絡(luò))同樣是一種生成...詳情>>

2023-10-15 06:10:12
什么是PLC?

一、什么是PLCPLC,全稱為 Programmable Logic Controller,中文名為可編程邏輯控制器。它是一種專為實現(xiàn)工業(yè)過程、生產(chǎn)線、機械裝置或某些其他...詳情>>

2023-10-15 05:26:08