简介mysql
今天记录下索引基础知识sql
一、mysql单表最多支持多少个索引,索引总长度为多少?mysql索引
索引是在存储引擎中实现的,所以每种存储引擎的索引都不必定彻底相同,而且每种存储引擎也不必定支持全部索引类型。编码
大多数存储引擎有更高的限制。MySQL中索引的存储类型有两种:BTREE和HASH,具体和表的存储引擎相关;.net
MYISAM和InnoDB存储引擎只支持BTREE索引;MEMORY和HEAP存储引擎能够支持HASH和BTREE索引3d
二、mysql在MySQL文档里,其实是把B+树索引写成了BTREE,以下图blog
千万别觉得mysql mysiam和innoDB用的是B树索引
三、mysql怎么建一个聚餐索引?文档
InnoDb将经过主键汇集数据,若是没有定义主键,InnoDB 会选择一个惟一的非空索引代替。若是没有这样的索引,InnoDB 会隐式定义一个主键来做为聚簇索引get
四、mysql索引长度限制
myisam表,单列索引,最大长度不能超过 1000 bytes;
innodb表,单列索引,最大长度不能超过 767 bytes;联合索引还有一个限制是长度不能超过3072
utf8 编码时 一个字符占三个字节
varchar 型能创建索引的最大长度分别为
myisam 1000/3 333
innodb 767/3 255
utf8mb4 编码时 一个字符占四个字节
varchar 型能创建索引的最大长度分别为
myisam 1000/4 250
innodb 767/4 191