MySQL explain的ken_len值计算方法

列类型KEY_LEN备注
id intkey_len = 4+1 = 5允许NULL,加1-byte
id int not nullkey_len = 4不允许NULL
user char(30) utf8key_len = 30*3+1允许NULL
user varchar(30) not null utf8key_len = 30*3+2动态列类型,加2-bytes
user varchar(30) utf8key_len = 30*3+2+1动态列类型,加2-bytes;允许NULL,再加1-byte
detail text(10) utf8key_len = 30*3+2+1TEXT列截取部分,被视为动态列类型,加2-bytes;且允许NULL

ps:字符编码是utf8,一个字符占用3个字节。

 

key_len的长度计算公式:

varchr(10)变长字段且允许NULL = 10 * ( character set:utf8=3,gbk=2,latin1=1)+1(NULL)+2(变长字段)

varchr(10)变长字段且不允许NULL = 10 *( character set:utf8=3,gbk=2,latin1=1)+2(变长字段)

char(10)固定字段且允许NULL = 10 * ( character set:utf8=3,gbk=2,latin1=1)+1(NULL)

char(10)固定字段且不允许NULL = 10 * ( character set:utf8=3,gbk=2,latin1=1)

bigint的长度是8bytes

int key_len长度是4 ,typeint的长度是1

smallint 长度是2 middleint长度是3

在这里 key_len 大小的计算规则是:
a、一般地,key_len 等于索引列类型字节长度,例如int类型为4-bytes,bigint为8 bytes;

b、如果是字符串类型,还需要同时考虑字符集因素,例如:CHAR(30) UTF8则key_len至少是90 bytes;

c、若该列类型定义时允许NULL,其key_len还需要再加 1 bytes;

d、若该列类型为变长类型,例如 VARCHAR(TEXT\BLOB不允许整列创建索引,如果创建部分索引,也被视为动态列类型),其key_len还需要再加 2 by

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值