题解 | #SQL 13.删除索引#

删除索引

http://www.nowcoder.com/practice/4963f6d63dde48d787aaa2b43460fb4b

明确考点:

索引创建、删除与使用:

  • 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上的索引

细节剖析:

  • 删除examination_info表上的唯一索引uniq_idx_exam_id;
  • 删除全文索引full_idx_tag;

思路实现:

  • 本题可采用第1种删除方式,根据细节剖析中的点组织完整语句:
DROP INDEX uniq_idx_exam_id ON examination_info;
DROP INDEX full_idx_tag ON examination_info;
  • 也可采用第2种删除方式:
alter table examination_info drop index uniq_idx_exam_id;
alter table examination_info drop index full_idx_tag;
SQL进阶 文章被收录于专栏

SQL进阶step by step

全部评论
感谢您的总结
点赞 回复 分享
发布于 2022-04-16 13:50

相关推荐

机械打工仔:我来告诉你原因,是因为sobb有在线简历,有些HR为了快会直接先看在线简历,初步感觉不合适就不会找你要详细的了
投了多少份简历才上岸
点赞 评论 收藏
分享
昨天 18:09
门头沟学院 Java
点赞 评论 收藏
分享
评论
50
7
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务