压缩表可以在 每表文件表 空间或 常规表空间中创建。表压缩不适用于InnoDB 系统表空间。系统表空间(空间0, .ibdata文件)可以包含用户创建的表,但也包含内部系统数据,该数据永远不会被压缩。因此,压缩仅适用于每个表文件或常规表空间中存储的表(和索引)。
在每表文件表空间中创建压缩表
要在每个表文件表空间中创建压缩表, innodb_file_per_table必须启用它(默认设置)。您可以在MySQL配置文件(my.cnf或 my.ini)中设置此参数,也可以使用SET 语句动态 设置此参数。
innodb_file_per_table 配置选项 后,在或 语句中指定ROW_FORMAT=COMPRESSED子句或 KEY_BLOCK_SIZE子句,或两者都指定 ,以 在每个表文件表空间中创建压缩表。 CREATE TABLEALTER TABLE
例如,您可以使用以下语句:
SET GLOBAL innodb_file_per_table=1;
CREATE TABLE t1
(c1 INT PRIMARY KEY)
ROW_FORMAT=COMPRESSED
KEY_BLOCK_SIZE=8;
在常规表空间中创建压缩表
要在常规表空间中创建压缩表, FILE_BLOCK_SIZE必须为常规表空间定义,该常规表空间是在创建表空间时指定的。该FILE_BLOCK_SIZE值必须是相对于该innodb_page_size值的有效压缩页面大小 ,并且由CREATE TABLEor 子句定义的压缩表的页面大小 必须等于 。例如,如果 表的和 , 必须为8。有关更多信息,请参见第15.6.3.3节“常规表空间”。 ALTER TABLE