影响MySQL 8.0单列索引长度的因素有哪些?

发布时间 2023-11-23 13:54:02作者: 高&玉

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。

参考:MySQL 8.0: InnoDB Limits