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
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库