1.MyISAM和InnoDB存储引擎:只支持BTREE索引,也就是说默认使用BTREE,不能够更换
MEMORY / HEAP存储引擎:支持HASH和BTREE索引
2.索引我们分为四类来讲单列索引(普通索引,唯一索引,主键索引),组合索引,全文索引,空间索引
单列索引:一个索引只包含单个列,但一个表中可以有多个单列索引。这里不要搞混淆了
普通索引:
MySQL的中基本索引类型,没有什么限制,允许在定义索引的列中插入重复值和空值,纯粹为了查询数据更快一点。
唯一索引:
索引列中的值必须是唯一的,但是允许为空值,
主键索引:
是一种特殊的唯一索引,不允许有空值。
索引组合
在表中的多个字段组合上创建³³的索引,只有在查询条件中使用了这些字段的左边字段时,索引才会被使用,使用组合索引时遵循最左前缀集合。这个如果还不明白,等后面举例讲解时在细说
全文索引
全文索引,只有在MyISAM引擎上才能使用,只能在CHAR,VARCHAR,TEXT类型字段上使用全文索引,介绍了要求,说说什么是全文索引,就是在一堆文字中,通过其中的某个关键字等,就能找到该字段所属的记录行,比如有“你是个大煞笔,二货...”通过大煞笔,可能就可以找到该条记录。这里说的是可能,因为全文索引的使用涉及了很多细节,我们只需要知道这个大概念思,如果感兴趣进一步深入使用它,那么看下面测试该索引时,会给出一个博文,供大家参考
索引空间
空间索引的英文对空间数据类型的字段建立的索引,MySQL的中的空间数据类型有四种,几何,点,LINESTRING,POLYGON
在创建空间索引时,使用空间关键字。要求,引擎为MyISAM数据,创建空间索引的列,必须将其声明为NOT NULL。具体细节看下面
3.创建索引
普通索引:INDEX(索引字段)KEY(索引字段)
唯一索引:UNIQUE INDEX UniqIdx(索引字段)
主键索引:PRIMARY KEY(索引字段)
INDEX MultiIdx(索引字段,索引字段,索引字段)
全文索引:FULLTEXT INDEX FullTxtIdx(索引字段)ENGINE = MyISAM
空间索引:SPATIAL INDEX spatIdx(索引字段)ENGINE = MyISAM