## 什么是MyISAM?
MyISAM是MySQL關系數據庫管理系統的默認儲存引擎(5.5之前)。這種MySQL表存儲結構從舊的ISAM代碼擴展 出許多有用的功能。在新版本的MySQL中,InnoDB引擎由于其對事務,參照完整性,以及更高的并發性等優點開始廣泛的取代MyISAM。
每一個MyISAM表都對應于硬盤上的三個文件。這三個文件有一樣的文件名,但是有不同的擴展名以指示其類型用途:.frm文件保存表的定義,但是這個文件并不是MyISAM引擎的一部分,而是服務器的一部分;.MYD保存表的數據;.MYI是表的索引文件。
## 什么是InnoDB?
InnoDB是MySQL的另一個存儲引擎,目前MySQL AB所發行新版的標準,被包含在所有二進制安裝包里,5.5之后作為默認的存儲引擎。較之于其它的存儲引擎它的優點是它支持兼容ACID的事務(類似于PostgreSQL),以及參數 完整性(即對外鍵的支持)。
Oracle公司與2005年10月收購了Innobase。Innobase采用雙認證授權。它使用GNU發行,也允許其它想將InnoDB結合到商業軟件的團體獲得授權。
目前比較普及的存儲引擎是MyISAM和InnoDB。MyISAM與InnoDB的主要的不同點在于性能和事務控制上。MyISAM是早期ISAM(Indexed Sequential Access Method,MySQL5.0之后已經不支持ISAM了)的擴展實現,ISAM被設計為適合處理讀頻率遠大于寫頻率這樣的情況,因此ISAM以及后來的MyISAM都沒有考慮對事物的支持,排除了TPM,不需要事務記錄,ISAM的查詢效率相當可觀,而且內存占用很少。
MyISAM在繼承了這類優點的同時,與時俱進地提供了大量實用的新特性和相關工具。例如考慮到并發控制,提供了表級鎖,雖然MyISAM本身不支持容錯,但可以通過 myisamchk進行故障恢復。而且由于MyISAM是每張表使用各自獨立的存儲文件(MYD數據文件和MYI索引文件),使得備份及恢復十分方便(拷貝覆蓋即可),而且還支持在線恢復。與其他存儲引擎比較,MyISAM具有檢查和修復表格的大多數工具. MyISAM表格可以被壓縮,而且它們支持全文(fulltext)搜索。它們不是事務安全的,而且也不支持外鍵所以如果你的應用是不需要事務,處理的只是基本的CRUD操作,那么MyISAM是不二選擇。
InnoDB被設計成適用于高并發讀寫的情況,使用MVCC(Multi-Version Concurrency Control)以及行級鎖來提供遵從ACID的事務支持。InnoDB支持外鍵參照完整性,具備故障恢復能力。另外 InnoDB的性能其實還是不錯的,特別是在處理大數據量的情況下,用官方的話說就是: InnoDB的CPU效率是其他基于磁盤的關系數據庫存儲引擎所不能比的。不過InnoDB的備份恢復要麻煩一點,除非你使用了4.1以后版本提供的 Mulit-tablespace支持,因為InnoDB和MyISAM不同,他的數據文件并不是獨立對應于每張表的。而是使用的共享表空間,簡單的拷貝覆蓋方法對他不適用,必須在停掉MYSQL后對進行數據恢復。使用Per-Table Tablespacesd,使其每張表對應一個獨立的表空間文件,則情況要簡單很多。它與BDB類型具有相同的特性,它們還支持外鍵。InnoDB表格速度很快,具有比BDB還豐富的特性,因此如果需要一個事務安全的存儲引擎,建議使用它。
一般來說,如果需要事務支持,并且有較高的并發讀寫頻率,InnoDB是不錯的選擇。要是并發讀寫頻率不高的話,其實可以考慮BDB,但由于在 MySQL5.1及其以后版本中,將不再提供BDB支持。這個選項也就沒有了
InnoDB默認情況下的事務是打開的(set autocommit = 0)就是說每插入一條記錄時候,InnoDB類型的表都會把它當作一個單獨的事務來處理.所以如果我們插入了10000條記錄,而且沒有將事務關閉,那么 InnoDB類型的表會把它當作10000個事務來處理,此時插入的總時間是很多的,這個時候一定要首先把事務關掉再插入,這樣的速度就很快了 至于Heap和BDB(Berkeley DB),相對來說,普及率不如前兩種,但在有些情況下,還是挺適用的Heap存儲引擎就是將數據存儲在內存中,由于沒有磁盤I/O的等待,速度極快。但由于是內存存儲引擎,所做的任何修改在服務器重啟后都將消失。Heap挺適合做測試的時候使用BDB是MySQL第一款事務安全的存儲引擎。在Berkeley DB database library的基礎上建立,同樣是事務安全的,但BDB的普及率顯然不及InnoDB,因為大多數在MySQL中尋找支持事務的存儲引擎的同時也在找支 持MVCC或是行級鎖定存儲引擎,而BDB只支持Page-level Lock。
## InnoDB引擎
InnoDB是一個事務型的存儲引擎,支持回滾,設計目標是處理大數量數據時提供高性能的服務,它在運行時會在內存中建立緩沖池,用于緩沖數據和索引。
### InnoDB引擎優點
1.支持事務處理、ACID事務特性;
2.實現了SQL標準的四種隔離級別;
3.支持行級鎖和外鍵約束;
4.可以利用事務日志進行數據恢復。
5.鎖級別為行鎖,行鎖優點是適用于高并發的頻繁表修改,高并發是性能優于 MyISAM。缺點是系統消耗較大。
6.索引不僅緩存自身,也緩存數據,相比 MyISAM 需要更大的內存。
### InnoDB引擎缺點
因為它沒有保存表的行數,當使用COUNT統計時會掃描全表。
## MyISAM引擎
MyISAM 是 MySQL 5.5.5 之前的默認引擎,它的設計目標是快速讀取。
### MyISAM引擎優點
1.高性能讀取;
2.因為它保存了表的行數,當使用COUNT統計時不會掃描全表;
### MyISAM引擎缺點
1.鎖級別為表鎖,表鎖優點是開銷小,加鎖快;缺點是鎖粒度大,發生鎖沖動概率較高,容納并發能力低,這個引擎適合查詢為主的業務。
2.此引擎不支持事務,也不支持外鍵。
3.INSERT和UPDATE操作需要鎖定整個表;
4.它存儲表的行數,于是SELECT COUNT(\*) FROM TABLE時只需要直接讀取已經保存好的值而不需要進行全表掃描。
## 適用場景
MyISAM適合:(1)做很多count 的計算;(2)插入不頻繁,查詢非常頻繁;(3)沒有事務。
InnoDB適合:(1)可靠性要求比較高,或者要求事務;(2)表更新和查詢都相當的頻繁,并且表鎖定的機會比較大的情況。
## 表格對比
| 屬性 | MyISAM | Heap | BDB | InnoDB |
| --- | --- | --- | --- | --- |
| 事務 | 不支持 | 不支持 | 支持 | 支持 |
| 鎖粒度 | 表鎖 | 表鎖 | 頁鎖(page, 8KB) | 行鎖 |
| 存儲 | 拆分文件 | 內存中 | 每個表一個文件 | 表空間 |
| 隔離等級 | 無 | 無 | 讀已提交 | 所有 |
| 可移植格式 | 是 | N/A | 否 | 是 |
| 引用完整性 | 否 | 否 | 否 | 是 |
| 數據主鍵 | 否 | 否 | 是 | 是 |
| MySQL緩存數據記錄 | 無 | 有 | 有 | 有 |
| 可用性 | 全版本 | 全版本 | MySQL-Max | 全版本 |
## 一些細節上的差別
1. InnoDB不支持FULLTEXT類型的索引,MySQL5.6之后已經支持(實驗性)。
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特性(例如外鍵)的表不適用。
6. 另外,InnoDB表的行鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的范圍,InnoDB表同樣會鎖全表。
- 簡介
- 前端
- html
- css
- css選擇器
- fiex布局
- 盒裝模型
- javascript
- 原型鏈
- 作用域
- 事件綁定
- dom
- bom
- jquery
- 選擇器
- jquery事件綁定
- layui
- bootstrap
- vue
- 路由(Vue Router)
- Vue CLI
- axios
- vant
- 打包部署
- 自定義組件
- 一些前端效果
- 點擊復制功能
- 后端
- php框架
- thinkphp
- 隱藏index.php
- thinkphp實現多表查詢
- thinkphp使用ajax單圖上傳
- thinkphp使用ajax圖集上傳
- thinkphp使用ajax查詢是否重名
- thinkphp使用ajax表單上傳
- where多個條件
- 郵件發送功能
- thinkphp短信寶發送短信
- tp5事務
- validate驗證二維數組
- yii2
- yii配置郵件
- yii的CRUD操作
- layui中兩種展示表單的方式
- laravel
- laravel實例
- laravel登錄
- laravel前端注冊
- laravel列表
- laravel刪除
- laravel編輯
- laravel新增
- Laravel 目錄結構
- Laravel 路由
- Laravel 控制器
- Laravel 模型讀操作
- Laravel 模型增、刪、改操作
- Laravel 中間件
- Laravel 視圖
- Laravel ,YII,thinkphp 框架的區別
- 會話控制
- session
- session存入redis
- session創建
- session刪除
- cookie
- 面向對象
- 三大特性
- 魔術方法
- 修飾符
- obj變量
- php
- php版本差異
- php7與php5的區別
- PHP 內存溢出問題
- 數據類型
- PHP 垃圾回收機制(GC)
- 文件目錄操作
- php函數
- 字符串相關函數
- 數組相關函數
- 超全局數組與超全局變量
- php魔術方法
- 引用變量
- php類庫
- 1.根據隨機數生成6位密鑰
- 2.獲取客戶端IP地址
- 3.多維數組變成一維數組
- 4.判斷是否是微信瀏覽器
- 5.判斷是否是移動端
- 6.隱藏手機號碼156***8956
- 7.隱藏郵箱 9533*****@qq.com
- 8.數組排序
- 9.添加操作日志
- 10.無線分類按子分類排序
- 11.從數組中刪除空白的元素
- 12.字符串相關類庫
- curl模擬post/get請求
- 替換中間四位數
- PHP地理位置計算
- 生成唯一訂單號
- 阿拉伯數字轉化為大寫
- 時間戳轉為中文時間
- php獲取本年、本月、本周時間戳和日期格式的實例代碼(分析)
- 去除數據庫的數據空格
- 壓縮Zip文件和文件打包下載
- PHP常用六大設計模式
- 單例模式
- 工廠模式
- 注冊樹模式
- 策略模式
- 適配器模式
- 觀察者模式
- 數據庫
- 留言板功能
- 所了解的數據庫
- sql server
- Memecached
- MongoDB
- mysql
- 存儲引擎(MyISAM與InnoDB)
- 庫表CRUD操作
- 索引
- 事務
- mysql常用命令
- 悲觀鎖和樂觀鎖
- 數據庫優化
- 大流量大并發優化
- Redis
- redis相關考點
- 開啟redis
- redis緩存cache
- redis存儲session
- redis限制提交次數
- 緩存雪崩,擊穿,穿透(copy)
- redis數據結構及使用場景
- 消息隊列
- Redis、Memecached 區別?
- phpstudy升級mysql版本
- 分表
- 讀寫分離
- linux
- 開發環境搭建
- mysql配置
- centos7(lnmp)環境搭建
- ubuntu(lnmp)環境搭建
- Nginx
- nginx四個基本功能
- nginx重啟出錯
- Nginx 的反向代理
- 用戶用戶組
- 虛擬機安裝
- linux常用命令
- chmod命令
- ubuntu下apt-get 命令
- 釋放內存
- 云鎖安裝及使用
- 大部隊搭建
- Centos開啟端口命令
- Centos禁止root登錄
- Centos7修改22端口
- Rsync備份
- 開啟端口
- 微信開發
- 輔助開發
- 網站SEO
- TCP/IP協議
- HTTP 請求全過程
- http狀態碼
- http和https的區別
- http請求三部分
- tcp三次握手
- 三次握手的作用
- tcp四次揮手
- CMS
- 織夢CMS
- 帝國cms
- wordpress
- 禪知cms
- 八大接口
- 微信支付
- 支付寶支付
- 郵件
- 微博登錄
- QQ登錄
- 快遞
- 天氣
- 常見算法
- 快速排序
- 冒泡排序
- 選擇排序
- 插入排序
- 二分查找
- 希爾排序
- V2Ray搭建
- AJAX
- GIT
- RBAC用戶權限管理數據庫設計
- 開發中遇到的一些問題
- 資料購買
- 建立ssr服務器
- 簡單建
- 申請并使用ssl證書
- 正則表達式手冊
- phpstorm
- 注冊碼
- 備用注冊碼
- 網站設計概要
- 網站相關功能代碼
- 權限(RBAC/AUTH)
- 無限級分類
- 記住登錄狀態
- email找回密碼
- 企業網站開發概要
- 網站后臺
- 文章管理
- 欄目管理 CRUD 上級欄目
- 欄目管理
- 友情鏈接
- 操作日志
- 登錄注冊
- 權限管理
- 網站配置
- 網站前臺
- 首頁
- 新聞動態
- 聯系
- 案例
- 關于
- 單店鋪商城開發概要
- 面試準備
- 有意思的面試題
- 拉鉤面試要求
- 慕課面試視頻知識總結
- 面試題匯總
- 題目1
- 一些工作的要求
- 前端炒的
- 面試項目介紹
- MySQL面試100 問
- 術語庫
- redis相關
- php操作redis
- redis消息隊列(異步)
- redis消息隊列(同步)