MySQL索引
1、推荐创建索引
1、主键自动建立唯一索引
2、频繁作为查询条件的字段应该创建索引(where 后面的语句)
3、查询中与其它表关联的字段,外键关系建立索引
4、多字段查询下倾向创建组合索引
5、查询中排序的字段,排序字段若通过索引去访问将大大提高排序速度
6、查询中统计或者分组字段
2、不推荐创建索引
1、表记录太少
2、经常增删改的表
3、Where条件里用不到的字段不建立索引
3、索引分类
1、主键索引
表中的列设定为主键后,数据库会自动建立主键索引。
单独创建和删除主键索引语法:
创建主键索引语法: alter table 表名 add primary key (字段);
删除主键索引语法: alter table 表名 drop primary key;
2、唯一索引
表中的列创建了唯一约束时,数据库会自动建立唯一索引。
单独创建和删除唯一索引语法:
创建唯一索引语法:alter table 表名 add unique 索引名(字段);
删除唯一索引语法:drop index 索引名 on 表名;
3、单值索引
建表时可随表一起建立单值索引
单独创建和删除单值索引语法:
创建单值索引:alter table 表名 add index 索引名(字段);
删除单值索引:drop index 索引名 on 表名;
4、复合索引
建表时可随表一起建立复合索引
单独创建和删除复合索引语法:
创建复合索引:alter table 表名 add index 索引名(字段,字段2);
删除复合索引:drop index 索引名 on 表名;