SQL之索引的创建与删除

1、知识点索引创建、删除与使用介绍

  • 1.1 create方式创建索引:

CREATE
  [UNIQUE -- 唯一索引
  | FULLTEXT -- 全文索引
  ] INDEX index_name ON table_name -- 不指定唯一或全文时默认普通索引
  (column1[(length) [DESC|ASC]] [,column2,...]) -- 可以对多列建立组合索引 
  • 1.2 alter方式创建索引:

ALTER TABLE tb_name ADD [UNIQUE | FULLTEXT] [INDEX] index_content(content)
  • 2.1 drop方式删除索引:

DROP INDEX <索引名> ON <表名>
  • 2.2 alter方式删除索引:

ALTER TABLE <表名> DROP INDEX <索引名>
  • 3.1 索引的使用:

    • 索引使用时满足最左前缀匹配原则,即对于组合索引(col1, col2),在不考虑引擎优化时,条件必须是col1在前col2在后,或者只使用col1,索引才会生效;
    • 索引不包含有NULL值的列
    • 一个查询只使用一次索引,where中如果使用了索引,order by就不会使用
    • like做字段比较时只有前缀确定时才会使用索引
    • 在列上进行运算后不会使用索引,如year(start_time)<2020不会使用start_time上的索引

2、案例

(1)现有一张试卷信息表examination_info,其中包含各种类型试卷的信息。为了对表更方便快捷地查询,需要在examination_info表创建以下索引,规则如下:

在duration列创建普通索引idx_duration、在exam_id列创建唯一性索引uniq_idx_exam_id、在tag列创建全文索引full_idx_tag。

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);

根据题意,将返回如下结果:

examination_info 0 PRIMARY 1 id A 0 BTREE
examination_info 0 uniq_idx_exam_id 1 exam_id A 0 YES BTREE
examination_info 1 idx_duration 1 duration A 0 BTREE
examination_info 1 full_idx_tag 1 tag 0 YES FULLTEXT

备注:后台会通过 SHOW INDEX FROM examination_info 语句来对比输出结果

(2)请删除examination_info表上的唯一索引uniq_idx_exam_id和全文索引full_idx_tag。

drop index uniq_idx_exam_id on examination_info;
drop index full_idx_tag on examination_info;

猜你喜欢

转载自blog.csdn.net/weixin_48272780/article/details/128329617
今日推荐