国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL InnoDB和MyISAM數據引擎的差別分析

2024-07-24 12:44:28
字體:
來源:轉載
供稿:網友
MyISAM類型的表強調的是性能,其執行數度比InnoDB類型更快,但是不提供事務支持,而InnoDB提供事務支持已經外部鍵等高級數據庫功能。

MyIASM是IASM表的新版本,有如下擴展:
二進制層次的可移植性。
NULL列索引。
對變長行比ISAM表有更少的碎片。
支持大文件。
更好的索引壓縮。
更好的鍵嗎統計分布。
更好和更快的auto_increment處理。

以下是一些細節和具體實現的差別:

1.InnoDB不支持FULLTEXT類型的索引。
2.InnoDB 中不保存表的具體行數,也就是說,執行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行,但是MyISAM只要簡單的讀出保存好的行數即可。注意的是,當count(*)語句包含 where條件時,兩種表的操作是一樣的。
3.對于AUTO_INCREMENT類型的字段,InnoDB中必須包含只有該字段的索引,但是在MyISAM表中,可以和其他字段一起建立聯合索引。
4.DELETE FROM table時,InnoDB不會重新建立表,而是一行一行的刪除。
5.LOAD TABLE FROM MASTER操作對InnoDB是不起作用的,解決方法是首先把InnoDB表改成MyISAM表,導入數據后再改成InnoDB表,但是對于使用的額外的InnoDB特性(例如外鍵)的表不適用。

另外,InnoDB表的行鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的范圍,InnoDB表同樣會鎖全表,例如update table set num=1 where name like “%aaa%”

任何一種表都不是萬能的,只用恰當的針對業務類型來選擇合適的表類型,才能最大的發揮MySQL的性能優勢。

您可能感興趣的文章:

MySql數據引擎簡介與選擇方法MySQL數據庫引擎介紹、區別、創建和性能測試的深入分析Mysql 開啟Federated引擎的方法mysql更改引擎(InnoDB,MyISAM)的方法MySQL存儲引擎總結mysql數據庫修改數據表引擎的方法MySQL Memory 存儲引擎淺析淺談MySQL存儲引擎選擇 InnoDB與MyISAM的優缺點分析mysql下修改engine引擎的方法mysql學習筆記之數據引擎
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 监利县| 阜宁县| 泉州市| 文化| 永善县| 西华县| 奈曼旗| 镇远县| 新源县| 东莞市| 天等县| 荣昌县| 北流市| 隆回县| 张家口市| 疏勒县| 日喀则市| 陵水| 邹城市| 东宁县| 沾益县| 安达市| 罗甸县| 南投县| 东阳市| 宁南县| 乐业县| 大冶市| 化州市| 东乌珠穆沁旗| 康乐县| 长顺县| 当涂县| 余江县| 高安市| 陕西省| 绵竹市| 贞丰县| 昭通市| 永川市| 新化县|