索引创建
create方式创建索引
CREATE [UNIQUE -- 唯一索引 | FULLTEXT -- 全文索引 ] INDEX index_name ON table_name -- 不指定唯一或全文时默认普通索引 (column1[(length) [DESC|ASC]] [,column2,...]) -- 可以对多列建立组合索引
alter方式创建索引
ALTER TABLE table_name ADD [UNIQUE | FULLTEXT] [INDEX] index_content(content)
例子: create index idx_duration on examination_info(duration) ; create unique index uniq_idx_exam_id on examination_info(exam_id); create fulltext index full_idx_tag on examination_info(tag); 或: alter table examination_info add index idx_duration(duration); alter table examination_info add unique index uniq_idx_exam_id(exam_id); alter table examination_info add fulltext index full_idx_tag(tag);
索引使用
- 索引使用时满足最左前缀匹配原则,即对于组合索引(col1, col2),在不考虑引擎优化时,条件必须是col1在前col2在后,或者只使用col1,索引才会生效;
- 索引不包含有NULL值的列
- 一个查询只使用一次索引,where中如果使用了索引,order by就不会使用
- like做字段比较时只有前缀确定时才会使用索引
- 在列上进行运算后不会使用索引,如year(start_time)<2020不会使用start_time上的索引
索引删除
drop方式删除索引
DROP INDEX <索引名> ON <表名>
alter方式删除索引
ALTER TABLE <表名> DROP INDEX <索引名>
例子: drop index uniq_idx_exam_id on examination_info; drop index full_idx_tag on examination_info; 或: alter table examination_info drop index uniq_idx_exam_id; alter table examination_info drop index full_idx_tag;