MySQL--索引

索引创建

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;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我是小bā吖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值