MySQL 8.0支持的单列索引长度最大是3072bytes,影响单列索引长度的因素有哪些:
- innodb_page_size: InnoDB页大小,默认是16KB。支持5种size:4k、8k、16k、32k、64k。
- row_format: 表的行格式,默认是“dynamic”。支持6种格式:DEFAULT、DYNAMIC、FIXED、COMPRESSED、REDUNDANT、COMPACT。
- character set: 如果使用“utf8mb4”,假如存储的是中文,那么一个字符占3bytes,那么该列支持的索引长度最大为(3072/3=1024)1024个字符。假如存储的是字母,那么一个字符占1bytes,那么该列支持的索引长度最大为3072bytes。
在row_format=DYNAMIC或COMPRESSED的情况下,innodb_page_size的size决定支持的单列索引最大长度不同。
- innodb_page_size=64KB,row_format=DYNAMIC或COMPRESSED,支持的单列索引最大长度是3072bytes。
- innodb_page_size=32KB,row_format=DYNAMIC或COMPRESSED,支持的单列索引最大长度是3072bytes。
- innodb_page_size=16KB,row_format=DYNAMIC或COMPRESSED,支持的单列索引最大长度是3072bytes。
- innodb_page_size=8KB,row_format=DYNAMIC或COMPRESSED,支持的单列索引最大长度是1536bytes。
- innodb_page_size=4KB,row_format=DYNAMIC或COMPRESSED,支持的单列索引最大长度是768bytes。
在innodb_page_size=16KB的情况下,row_format的格式决定支持的单列索引最大长度不同。
- row_format=DYNAMIC或COMPRESSED,支持的单列索引最大长度是3072bytes。
- row_format=COMPACT或REDUNDANT,支持的单列索引最大长度是767bytes。