博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySql 创建索引原则
阅读量:7236 次
发布时间:2019-06-29

本文共 866 字,大约阅读时间需要 2 分钟。

为了使索引的使用效率更高,在创建索引时,必须考虑在哪些字段上创建索引和创建什么类型的索引。本小节将向读者介绍一些索引的设计原则。
 
1.选择唯一性索引
 
唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录。例如,学生表中学号是具有唯一性的字段。为该字段建立唯一性索引可以很快的确定某个学生的信息。如果使用姓名的话,可能存在同名现象,从而降低查询速度。
 
2.为经常需要排序、分组和联合操作的字段建立索引
 
经常需要ORDER BY、GROUP BY、DISTINCT和UNION等操作的字段,排序操作会浪费很多时间。如果为其建立索引,可以有效地避免排序操作。
 
3.为常作为查询条件的字段建立索引
 
如果某个字段经常用来做查询条件,那么该字段的查询速度会影响整个表的查询速度。因此,为这样的字段建立索引,可以提高整个表的查询速度。
 
4.限制索引的数目
 
索引的数目不是越多越好。每个索引都需要占用磁盘空间,索引越多,需要的磁盘空间就越大。修改表时,对索引的重构和更新很麻烦。越多的索引,会使更新表变得很浪费时间。
 
5.尽量使用数据量少的索引
 
如果索引的值很长,那么查询的速度会受到影响。例如,对一个CHAR(100)类型的字段进行全文检索需要的时间肯定要比对CHAR(10)类型的字段需要的时间要多。
 
6.尽量使用前缀来索引
 
如果索引字段的值很长,最好使用值的前缀来索引。例如,TEXT和BLOG类型的字段,进行全文检索会很浪费时间。如果只检索字段的前面的若干个字符,这样可以提高检索速度。
 
7.删除不再使用或者很少使用的索引
 
表中的数据被大量更新,或者数据的使用方式被改变后,原有的一些索引可能不再需要。 管理员应当定期找出这些索引,将它们删除,从而减少索引对更新操作的影响。
 

注意:选择索引的最终目的是为了使查询的速度变快。上面给出的原则是最基本的准则,但不能拘泥于上面的准则。读者要在以后的学习和工作中进行不断的实践。根据应用的实际情况进行分析和判断,选择最合适的索引方式。

PS: MySQL创建索引

PS:MySQL 索引类型

转载地址:http://apwbm.baihongyu.com/

你可能感兴趣的文章
浅谈Vim
查看>>
高端数据中心交换机散热系统大比拼
查看>>
Jira Epic在完成状态时,如何让Epic在Scrum面板待办事项中不显示?
查看>>
整理一下Entity Framework的查询
查看>>
添加引号的 java 正则表达式5
查看>>
关于IDEA不能实时编译的一个临时解决办法。。。。
查看>>
smali文件对比java文件(转)
查看>>
SpringBoot2.0 配置Log4j2记录日志
查看>>
JS 获取 CSS 样式
查看>>
使用myeclipse的反向工程来生成相应的hibernate映射文件和POJO类
查看>>
正则 基本用法
查看>>
产品上线前如何搭建团队运营体系
查看>>
Android 4.2蓝牙介绍
查看>>
Google资深工程师详解Android的系统架构
查看>>
我的友情链接
查看>>
Zookeeper使用和原理探究(一)
查看>>
awk中的NR和FNR的区别
查看>>
Android Animation动画
查看>>
四、变量、作用域和内存问题
查看>>
基于maven使用IDEA创建多模块项目
查看>>