亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL 選擇合適的存儲引擎

瀏覽:2日期:2023-10-11 14:39:30

對于數(shù)據(jù)庫這一塊詢問比較多的就是在 MySQL 中怎么去選擇一種何時當(dāng)前業(yè)務(wù)需求的存儲引擎,而 MySQL 中支持的存儲引擎又有很多種,那么 MySQL 中分別又有那些,怎么優(yōu)雅的使用呢?

劃分引擎原因

在文件系統(tǒng)中,MySQL 將每個數(shù)據(jù)庫(也可以稱之為 schema )保存為數(shù)據(jù)目錄下的一個子目錄。創(chuàng)建表時,MySQL 會在數(shù)據(jù)庫子目錄下創(chuàng)建一個和表同名的 .frm 文件保存表的定義。例如創(chuàng)建一個名為 DebugTable 的表,MySQL 會在 DebugTable.frm 文件中保存該表的定義。

因為 MySQL 使用文件系統(tǒng)的目錄和文件來保存數(shù)據(jù)庫和表的定義,大小寫敏感性和具體的平臺密切相關(guān)。在 Windows 系統(tǒng)中,大小寫是不敏感的;而在類 Unix 系統(tǒng)中則是敏感的。不同的存儲引擎保存數(shù)據(jù)和索引的方式是不同的,但表的定義則是在 MySQL 服務(wù)層wk統(tǒng)一處理的。

查看支持引擎

想了解 MySQL 中支持的引擎的情況,可以使用如下命令查看:

show engines;

結(jié)果如下(MySQL版本:Ver 8.0.19):

mysql> show engines;+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+| Engine | Support | Comment | Transactions | XA | Savepoints |+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+| FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL || MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO || InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES || PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO || MyISAM | YES | MyISAM storage engine | NO | NO | NO || MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO || BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO || CSV| YES | CSV storage engine | NO | NO | NO || ARCHIVE | YES | Archive storage engine | NO | NO | NO |+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+9 rows in set (0.00 sec)

存儲引擎分類

MySQL 存儲引擎分類有 MyISAM、InnoDB、Memory、Merge等,可以看上面表中列出的支持引擎,但是其中最為常用的就是 MyISAM 和 InnoDB 兩個引擎,其中針對于以上講到的存儲引擎,如下表進(jìn)行對比:

MySQL 選擇合適的存儲引擎

MyISAM 與 InnoDB 區(qū)別

兩種類型最主要的差別是InnoDB支持事務(wù)處理與外鍵和行級鎖。

InnoDB 可借由事務(wù)日志( Transaction Log )來恢復(fù)程序崩潰( crash ),或非預(yù)期結(jié)束所造成的數(shù)據(jù)錯誤;而 MyISAM 遇到錯誤,必須完整掃描后才能重建索引,或修正未寫入硬盤的錯誤。 InnoDB 的修復(fù)時間,一般都是固定的,但 MyISAM 的修復(fù)時間,則與數(shù)據(jù)量的多寡成正比。 相對而言,隨著數(shù)據(jù)量的增加,InnoDB 會有較佳的穩(wěn)定性。 MyISAM 必須依靠操作系統(tǒng)來管理讀取與寫入的緩存,而 InnoDB 則是有自己的讀寫緩存管理機(jī)制。( InnoDB 不會將被修改的????立即交給操作系統(tǒng))因此在某些情況下,InnoDB 的數(shù)據(jù)訪問會比 MyISAM 更有效率。 InnoDB 目前并不支持 MyISAM 所提供的壓縮與 terse row formats(簡潔的行格式) ,所以對硬盤與高速緩存的使用量較大。 當(dāng)操作完全兼容 ACID(事務(wù))時,雖然 InnoDB 會自動合并數(shù)筆連接,但每次有事務(wù)產(chǎn)生時,仍至少須寫入硬盤一次,因此對于某些硬盤或磁盤陣列,會造成每秒 200 次的事務(wù)處理上限。若希望達(dá)到更高的性能且保持事務(wù)的完整性,就必使用磁盤緩存與電池備援。當(dāng)然 InnoDB 也提供數(shù)種對性能沖擊較低的模式,但相對的也會降低事務(wù)的完整性。而MyISAM則無此問題,但這并非因為它比較先進(jìn),這只是因為它不支持事務(wù)。

應(yīng)用場景

MyISAM 管理非事務(wù)表。它提供高速存儲和檢索,以及全文搜索能力。如果應(yīng)用中需要執(zhí)行大量的 SELECT 查詢,那么 MyISAM 是更好的選擇。 InnoDB 用于事務(wù)處理應(yīng)用程序,具有眾多特性,包括 ACID 事務(wù)支持。如果應(yīng)用中需要執(zhí)行大量的 INSERT 或 UPDATE 操作,則應(yīng)該使用 InnoDB,這樣可以提高多用戶并發(fā)操作的性能。

以上就是MySQL 存儲引擎的選擇的詳細(xì)內(nèi)容,更多關(guān)于MySQL 存儲引擎的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 国产日本在线视频 | 拍拍视频免费观看网站在线观看 | 狼人青草久久网尹人 | 国产又黄又潮娇喘视频免费 | 亚洲成a人片毛片在线 | 91精品国产综合久久青草 | 国产精品资源在线播放 | 女人被狂躁的视频免费一一 | 免看一级a毛片一片成人不卡 | 国产噜噜在线视频观看 | 肉体秘书hd中文字幕 | 黄色网zhan | 91国视频在线 | 久久亚洲精品国产精品777777 | 日韩欧美精品综合久久 | 婷婷月 | 国内自拍视频在线观看 | 久久精品视频在线播放 | 在线免费观看日韩视频 | 婷婷色国产 | 欧美视频免费一区二区三区 | 尤物精品 | 亚洲人成黄网在线观看 | 久青草免费视频手机在线观看 | 国产在线观看成人 | 国产在线观看的 | 久久精品视频在线观看榴莲视频 | 欧美高清一区二区三 | 国产美女天天爽在线hd | 国产精品一区二区久久精品 | 国产精选在线 | 婷婷性 | 大量国产后进翘臀视频 | 国产老肥熟xxxx | 1024在线观看 | 久久免费99精品久久久久久 | 狠狠亚洲婷婷综合色香五 | 12306影院午夜入口 | 国产成人精品免费视频网页大全 | 成人毛片100部免费看 | 无套国产|