01.MyISAM 01.MyISAM MySQL 5.0 以前的預設存儲引擎。MyISAM 不支持事務、也不支持外鍵,其優勢是訪問的速度快,對事務完整性沒有要求或者以SELECT、INSERT 為主的應用基本上都可以使用這個引擎來創建表。 每個MyISAM 在磁碟上存儲成3 個文件,其文件名都和表 ...
01.MyISAM MySQL 5.0 以前的預設存儲引擎。MyISAM 不支持事務、也不支持外鍵,其優勢是訪問的速度快,對事務完整性沒有要求或者以SELECT、INSERT 為主的應用基本上都可以使用這個引擎來創建表。 每個MyISAM 在磁碟上存儲成3 個文件,其文件名都和表名相同,但擴展名分別是: .frm(存儲表定義); .MYD(MYData,存儲數據); .MYI (MYIndex,存儲索引)。 數據文件和索引文件可以放置在不同的目錄,平均分佈IO,獲得更快的速度。 要指定索引文件和數據文件的路徑,需要在創建表的時候通過DATA DIRECTORY 和INDEX DIRECTORY 語句指定,也就是說不同MyISAM 表的索引文件和數據文件可以放置到不同的路徑下。文件路徑需要是絕對路徑,並且具有訪問許可權。 MyISAM 類型的表可能會損壞,原因可能是多種多樣的,損壞後的表可能不能訪問,會提示需要修複或者訪問後返回錯誤的結果。MyISAM 類型的表提供修複的工具,可以用CHECKTABLE 語句來檢查MyISAM 表的健康,並用REPAIR TABLE 語句修複一個損壞的MyISAM 表。表損壞可能導致資料庫異常重新啟動,需要儘快修複並儘可能地確認損壞的原因。 MyISAM 的表又支持3 種不同的存儲格式,分別是: 靜態(固定長度)表; 動態表; 壓縮表。 其中,靜態表是預設的存儲格式。靜態表中的欄位都是非變長欄位,這樣每個記錄都是固定長度的,這種存儲方式的優點是存儲非常迅速,容易緩存,出現故障容易恢復;缺點是占用的空間通常比動態表多。靜態表的數據在存儲的時候會按照列的寬度定義補足空格,但是在應用訪問的時候並不會得到這些空格,這些空格在返回給應用之前已經去掉。 動態表中包含變長欄位,記錄不是固定長度的,這樣存儲的優點是占用的空間相對較少,但是頻繁地更新刪除記錄會產生碎片,需要定期執行OPTIMIZE TABLE 語句或myisamchk -r 命令來改善性能,並且出現故障的時候恢復相對比較困難。 壓縮表由myisampack 工具創建,占據非常小的磁碟空間。因為每個記錄是被單獨壓縮的,所以只有非常小的訪問開支。 02.InnoDB MySQL 5.0開始的預設引擎,InnoDB 存儲引擎提供了具有提交、回滾和崩潰恢復能力的事務安全。但是對比MyISAM的存儲引擎,InnoDB 寫的處理效率差一些並且會占用更多的磁碟空間以保留數據和索引。 AUTO_INCREMENT InnoDB 表的自動增長列可以手工插入,但是插入的值如果是空或者0,則實際插入的將是自動增長後的值。 可以通過“ALTER TABLE *** AUTO_INCREMENT = n;”語句強制設置自動增長列的初識值,預設從1 開始,但是該強制的預設值是保留在記憶體中的,如果該值在使用之前資料庫重新啟動,那麼這個強制的預設值就會丟失,就需要在資料庫啟動以後重新設置。 可以使用LAST_INSERT_ID()查詢當前線程最後插入記錄使用的值。如果一次插入了多條記錄,那麼返回的是第一條記錄使用的自動增長值。 對於InnoDB 表,自動增長列必須是索引。如果是組合索引,也必須是組合索引的第一列,但是對於MyISAM 表,自動增長列可以是組合索引的其他列,這樣插入記錄後,自動增長列是按照組合索引的前面幾列進行排序後遞增的。 例如,創建一個新的MyISAM 類型的表autoincre_demo,自動增長列d1 作為組合索引的第二列,對該表插入一些記錄後,可以發現自動增長列是按照組合索引的第一列d2 進行排序後遞增的:


-
1 ALTER TABLE tbl_name DISCARD TABLESPACE; 2 ALTER TABLE tbl_name IMPORT TABLESPACE;








