主页 > 知识库 > mysql高级学习之索引的优劣势及规则使用

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

热门标签:铁路电话系统 地方门户网站 网站排名优化 服务外包 呼叫中心市场需求 Linux服务器 AI电销 百度竞价排名

一、索引的优劣势

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

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

二、索引的分类

主键索引 即主索引,根据主键 pk_clolum(length)建立索引,不允许重复,不允许空值
唯一索引 用来建立索引的列的值必须是唯一的,允许空值
普通索引 用表中的普通列构建的索引,没有任何限制
全文索引 用大文本对象的列构建的索引
全文索引 用大文本对象的列构建的索引;
组合索引 用多个列组合构建的索引,这多个列中的值不允许有空值。

三、使用索引的规则

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

2、创建表过后添加索引

-- 添加索引
-- myindex索引的名字(自己定义)
-- mytable 表的名字
CREATE INDEX myindex ON mytable(username(16));
或者
ALTER TABLE mytable ADD INDEX myindex(username);

3 查看索引

-- mytable 表的名字
 show index FROM mytable;

4、删除索引

-- myindex索引的名字(自己定义)
-- mytable 表的名字
DROP INDEX myindex ON mytable;
或者
ALTER TABLE mytable DROP INDEX myindex;

总结

到此这篇关于mysql高级学习之索引的优劣势及规则使用的文章就介绍到这了,更多相关mysql高级索引内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • mysql 添加索引 mysql 如何创建索引
  • MySQL索引类型总结和使用技巧以及注意事项
  • MySQL查看、创建和删除索引的方法
  • MySQL 创建索引(Create Index)的方法和语法结构及例子
  • mysql性能优化之索引优化
  • Mysql索引会失效的几种情况分析
  • MySQL 主键与索引的联系与区别分析
  • 基于mysql全文索引的深入理解
  • 解决MySQL中IN子查询会导致无法使用索引问题
  • MySQL 索引分析和优化

标签:铜川 湖南 兰州 湘潭 崇左 衡水 黄山 仙桃

巨人网络通讯声明:本文标题《mysql高级学习之索引的优劣势及规则使用》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266