在数据库中合理的使用索引是提升mysql数据库的一种高效和快捷的方式,但是在索引的使用上在我的使用中发现有很多坑,因为自己之前没有认识到,所以来总结一下


索引的介绍

索引是一种特殊的文件,其中包含着对数据表中的所有记录的引用指针

添加索引的条件

  1. 字段中存储的内容重复性不能过高,比如性别,颜色等这些可区分性很低的字段

  2. 字段会经常性的用作查询语句。 因为创建索引也是需要存储的空间的,而且创建了索引会造成insert等语句的速度变慢

  3. 字段更新的斌率不高的字段适合添加索引。数据的更新会带来索引的更新。

索引的类型

  1. 普通索引 : key 。唯一的作用就是加快查询的速度

  2. 主键索引 : primary key 。字段具备唯一性 一张数据表中只有一个

  3. 唯一索引 : unique key 。

  4. 联合索引 : key(a,b,c)

  5. 外键索引 : 在我现在的认识中,就是用来维护数据表之间的相关性的,并且会导致数据的写入等操作的速度过慢,所以。。好像没啥用(对于较大的项目)

  6. 全文索引 : FULLTEXT(column1, column2) mysql5.6以前的InnoDB表不支持。使用:WHERE MATCH(column) AGAINST('search_content')

索引在使用上的注意点

  1. 索引字段上使用 WHERE DAY(column)='' 或 WHERE column*2=100这种运算,索引不会被使用到

  2. 在索引的字段上 使用NOT IN,<>,!=这些运算符的时候,执行explain会使用到索引,但是这些操作是不被推崇的,因为就算是用到了索引速度也不会很快.而且在mysql的5.6版本以前这种方式就算执行explain操作也是是用不到索引的

  3. 在索引字段上使用 likeregexp操作的时候,%的通配符不能放在要查找的字符串的左侧(可以想象使用索引的时候就是在查字典,比如想要找到'mysql'这个单词,需要从m开始,然后是y,所以查询的顺序就是从左往右的)

  4. 关于联合索引的一些注意事项:

    1. 如果给一张表添加的一组联合索引如下: key(name,email,age) ,mysql在添加联合索引的时候以‘最左前缀’的形式进行索引的添加,那么在进行查询select *的时候[name] [name,email] [name,email,age] 这三组查询条件都是可以使用到这个组合索引的,但是这并不是重点

    2. 如果现在使用 explain select * from table where age=11会发现索引并没有被使用到。 可是执行 explain select name,email from table where age=11 .会发现这个索引被使用到了。 这种方式叫做索引覆盖,在执行explain语句的时候,会发现extra一栏中卫'Using Index',如果存储引擎使用的是InnoDB,二级索引也存储了primary key的值,如果用过索引去访问primary key的值,也可以访问到

  5. 还有就是 关于添加联合索引还是单列索引的问题。如果字段都被添加成单列的索引,相比于联合索引的话,会增加数据库的IO的等待

  6. 索引的确可以加快mysql在查询时候的速度。但是在数据进行新增及更新等操作的时候,也需要对应的维护索引关系(但是也有配置可以在数据:DELAY_KEY_WRITE,不深入展开)

  7. 在使用多个条件进行数据的查询的时候,有网上的很多说法都是mysql中单次sql的查询只能使用到一个索引(这个是错误的!!) 一条sql语句,针对一张表的查询,多个条件之间使用and拼接的话,索引在mysql内部会被执行 union的操作,索引是可以使用到的! 但是!如果条件之间使用or进行条件的拼接的话,那么如果想要该语句的索引有效就必须保证每个被or连接的条件都可以使用到索引。

索引的长度

比如果我现在想要给 用户表的用户家庭住址字段添加索引,该字段:address 的类型为varchar(255) ,对整个字段建立索引的话肯定是不合理的,这个时候需要为该字段的前n个值建立索引。可以使用 
select count(distinct substring(字段,1,结束位置)) from 表
对比一下表中的总数据看一下该n值得选择性,用来确定索引的长度

Mysql 中创建索引和索引的使用问题的更多相关文章

  1. Mysql中主键与索引

    摘自: https://www.cnblogs.com/wicub/p/5898286.html 一.什么是索引?索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存.如果没 ...

  2. MySQL如何创建一个好索引?创建索引的5条建议【宇哥带你玩转MySQL 索引篇(三)】

    MySQL如何创建一个好索引?创建索引的5条建议 过滤效率高的放前面 对于一个多列索引,它的存储顺序是先按第一列进行比较,然后是第二列,第三列...这样.查询时,如果第一列能够排除的越多,那么后面列需 ...

  3. mysql 中创建存储过程

    mysql中创建存储过程和存储函数虽相对其他的sql语言相对复杂,但却功能强大,存储过程和存储函数更像是一种sql语句中特定功能的一种封装,这种封装可以大大简化外围调用语句的复杂程度. 首先以表emp ...

  4. 在MySQL中创建实现自增的序列(Sequence)的教程

    这篇文章主要介绍了在MySQL中创建实现自增的序列(Sequence)的教程,分别列举了两个实例并简单讨论了一些限制因素,需要的朋友可以参考下 项目应用中,曾有以下一个场景: 接口中要求发送一个int ...

  5. EF Core使用CodeFirst在MySql中创建新数据库以及已有的Mysql数据库如何使用DB First生成域模型

    官方教程:https://docs.microsoft.com/en-us/aspnet/core/data/?view=aspnetcore-2.1 使用EF CodeFirst在MySql中创建新 ...

  6. C# 利用mysql.data 在mysql中创建数据库及数据表

    C# 利用mysql.data 在mysql中创建数据库及数据表 using System; using System.Collections.Generic; using System.Linq; ...

  7. mysql中创建函数时报错信息

    报错信息如下 ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its ...

  8. 高性能mysql:创建高性能的索引

    本文系阅读<高性能MySQL>,Baron Schwartz等著一书中第五章 创建高性能的索引的笔记,索引是存储引擎用于快速找到记录的一种数据结构. 索引对于良好的性能非常关键,尤其是当表 ...

  9. SqlServer中创建非聚集索引和非聚集索引

    聚集索引与非聚集索引,其实已经有很多的文章做过详细介绍. 非聚集索引 简单来说,聚集索引是适合字段变动不大(尽可能不出现Update的字段).出现字段重复率小的列,因为聚集索引是对数据物理位置相同的索 ...

随机推荐

  1. while(cin>>word)时的结束方法

    有一个要注意的地方,以前不理解在while里面用cin >> val是什么意思,用这个当条件的话,通过检测其流的状态来判断结束: (1)若流是有效的,即流未遇到错误,那么检测成功: (2) ...

  2. 继承Spring AbstractRoutingDataSource实现路由切换

    继承Spring AbstractRoutingDataSource实现路由切换 原创 2016年05月11日 16:50:08 标签: mybatis / AbstractRoutingDataS  ...

  3. IntelliJ IDEA 2017.2.2 的破解 有效期 2116年

      破解三部曲 下载破解文件 JetbrainsCrack-2.6.6-release-enc.jar http://idea.lanyus.com/jar/JetbrainsCrack-2.6.6- ...

  4. 警告: [SetContextPropertiesRule]{Context} Setting property 'source' to 'org.eclipse.jst.jee.server:

    当你用Eclipse运行web项目的时候,你就会看到控制台出现: 警告: [SetContextPropertiesRule]{Context} Setting property 'source' t ...

  5. BeanUtils 装载java bean

    Topic topic=new Topic(); Enumeration<String> enums=request.getParameterNames(); try { while(en ...

  6. SSAS多维数据集以及维度的建立

    首先打开vs建立一个Analysis Services项目,然后点击数据源文件右键[新建数据源],根据数据源向导建立自己的数据源,如图1: 点击[确定],选择刚才的数据连接,点击[下一步]进入模拟信息 ...

  7. OAF_OAF增删改-新增的实现(案例)

    2014-09-14 Created By BaoXinjian

  8. 机器学习(6): 层次聚类 hierarchical clustering

    假设有N个待聚类的样本,对于层次聚类来说,步骤:        1.(初始化)把每个样本归为一类,计算每两个类之间的距离,也就是样本与样本之间的相似度:        2.寻找各个类之间最近的两个类, ...

  9. 如何判断SCI期刊投稿难易度和审稿周期

    如何判断SCI期刊投稿难易度和审稿周期 要发SCI论文,前提当然是必须有一篇写好的英文论文,SCI都是英文的杂志,这个大家应该都懂的     首先谈谈投稿难易程度很多人似乎都一种误解,认为拒稿率高的杂 ...

  10. 使用国内镜像源安装npm包报错

    1 使用命令安装 npm install webpack --save-dev 可能是版本太高,国内没有更新. 通过设置镜像源 npm config set registry http://regis ...