innodb 目前支持兩種文件格式(innodb_file_format) Antelope 和Barracuda
創(chuàng)新互聯(lián)公司是一家以成都網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、品牌設(shè)計、軟件運維、網(wǎng)站推廣、小程序App開發(fā)等移動開發(fā)為一體互聯(lián)網(wǎng)公司。已累計為自拌料攪拌車等眾行業(yè)中小客戶提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開發(fā)服務(wù)。
5.6 默認的是 Antelope (羚羊) ,有兩種“數(shù)據(jù)表格式”(row_format):Redundant(冗余)、Compact(緊湊)
5.7 默認的是 Barracuda (梭子魚) 原來的基礎(chǔ)上新增了兩種數(shù)據(jù)表格式的支持:Dynamic 和 Compressed
一、 如何設(shè)置MySQL innodb 表的壓縮
設(shè)置innodb 表的 壓縮
第一,mysql的版本需要大于5.5
第二,設(shè)置innodb_file_format=barracuda
innodb_file_format=barracuda
innodb_file_per_table = 1
innodb_strict_mode=1 #建議加上
innodb_default_row_format = COMPRESSED #在整個庫默認啟用行壓縮格式時設(shè)定,一邊不改變此值
第三,create table或者alter talble 增加 ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8;
鑒于InnoDB表的最大行大小約為8K,KEY_BLOCK_SIZE=8通常是一個安全的選擇
在緩沖池中,壓縮數(shù)據(jù)保存在小頁面中,頁面大小基于該KEY_BLOCK_SIZE 值
KEY_BLOCK_SIZE默認為innodb_page_size值的一半,也就是8k