MySQL 中索引长度计算公式
所有的索引字段,如果没有设置 Not Null,则需要加一个字节(这也是我们为什么建议建表时不要有 Null 字段的原因之一)。
对于定长字段,int 类型占四个字节、date 占三个字节、char(n) 占 N 个字符。
对于变成字段 varchar(n),则是 N 个字符 + 两个字节。
不同的字符集,一个字符占用的字节数不同。latin1编码的,一个字符占用一个字节,gbk编码的,一个字符占用两个字节,utf8编码的,一个字符占用三个字节。
索引长度 char()、varchar() 索引长度的计算公式:
Character Set:utf8mb4=4,utf8=3,gbk=2,latin1=1) * 列长度 + 1(允许 Null) + 2(变长列)
索引长度计算公式验证
CREATE TABLE `tb_item` (
`id` bigint NOT NULL COMMENT '书籍id,同时也是书籍编号',
`title` varchar(100) NOT NULL COMMENT '书籍名称',
`sell_point` varchar(500) DEFAULT NULL COMMENT '书籍卖点',
`price` bigint NOT NULL COMMENT '书籍价格,单位为:分',
`num` int NOT NULL COMMENT '库存数量',
`barcode` varchar(30) DEFAULT NULL COMMENT '书籍条形码',
`image` varchar(500) DEFAULT NULL COMMENT '书籍图片',
`cid` bigint NOT NULL COMMENT '所属类目,叶子类目',
`status` tinyint NOT NULL DEFAULT '1' COMMENT '书籍状态,1-正常,2-下架,3-删除',
`created` datetime NOT NULL COMMENT '创建时间',
`updated` datetime NOT NULL COMMENT '更新时间',
`upload_id` bigint DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `cid` (`cid`),
KEY `status` (`status`),
KEY `updated` (`updated`),
KEY `tb_item_title_price_num` (`title`,`price`,`num`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8 COMMENT '商品表';
tb_item_title_price_num
,由三个字段组成,分别是变长字段 varchar,定长字段 price 以及 num。explain select * from tb_item where title = '编译原理' and price = 45 and num = 23232
;tb_item_title_price_num
,同时索引长度 key_len 为 314 ,证明是使用到了联合索引 tb_item_title_price_num
的三个完整字段的。explain select * from tb_item where title = '编译原理' and num = 23232
Using index condition
,说明使用了索引,但是需要回表查询数据。总结