欢迎来到IDC91站长网!
解决服务器各种技术问题,加微信uecomzsr

MySQL

当前位置: IDC91 > 数据库 > MySQL

mysql高级学习之索引的优劣势及规则使用

时间:2022-05-30 13:55:04|栏目:MySQL|点击:

一、索引的优劣势

优点:可以快速的检索 、可以加快分组和排序

缺点: 占用储存空间、降低数据表的修改操作

二、索引的分类

三、使用索引的规则

1、适合建立索引的情况

  • 主键自动建立唯一索引;
  • 经常作为查询条件在 WHERE 或者 ORDER BY 语句中出现的列要建立索引;
  • 作为排序的列要建立索引;
  • 查询中与其他表关联的字段,外键关系建立索引;
  • 高并发条件下倾向组合索引;
  • 用于聚合函数的列可以建立索引,例如使用了 max(column_1)或者count(column_1)时的 column_1 就需要建立索引。

2、不适合建立索引的情况

  • 经常增删改的列不要建立索引;
  • 有大量重复的列不建立索引;
  • 表记录太少不要建立索引。

3、索引失灵的情况

  • 在组合索引中不能有列的值为 NULL,如果有,那么这一列对组合索引就是无效的;
  • LIKE 操作中,'%aaa%'不会使用索引,也就是索引会失效,但是‘aaa%'可以使用索引;
  • 在索引的列上使用表达式或者函数会使索引失效;
  • 在查询条件中使用不等于,包括<符号、>符号和!=会导致索引失效;
  • 在查询条件中使用 IS NULL 或者 IS NOT NULL 会导致索引失效;
  • 字符串不加单引号会导致索引失效;
  • 在查询条件中使用 OR 连接多个条件会导致索引失效,除非 OR 链接的每个条件都加上索引;
  • 如果排序的字段使用了索引,那么 select 的字段也要是索引字段,否则索引失效;
  • 尽量不要包括多列排序,如果一定要,最好为这队列构建组合索引。

四、关于索引的SQL

1、创建表的时候添加索引

-- 创建表的时候添加索引
-- INDEX 关键词
-- myindex 索引的名称自己起的
-- (username(16))添加到哪一个字段上
CREATE TABLE mytable(
 ID INT NOT NULL,
 username VARCHAR(16) NOT NULL,
 INDEX myindex (username(16))
);

上一篇:mysql索引失效的几种情况分析

栏    目:MySQL

下一篇:MySQL查询优化必备知识点总结

本文标题:mysql高级学习之索引的优劣势及规则使用

本文地址:https://idc91.com/shujuku/3863.html

广告投放 | 联系我们 | 免责申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

Copyright © 2023 IDC91.COM 版权所有晋ICP备17006296号