MySQL学习之索引顺序

2019-03-02 11:29:17

做为一个PHP开发者,关于MySQL的索引是必不可少的一个问题

比如一条SQL查询:

select * from userstatic where nick like "辛巴%" and rip=3726854906;

可能问到的问题有:

1、如果nick不是索引,rip是索引,这样的条件顺序会不会有问题?

     这个问题比较简单,MySQL本身会对条件和索引进行判断,这样写可以用到索引,没有问题。

2、如果nick和rip都是索引,这样写有没有问题?

     我们都知道,一次查询只能使用一个索引,到底怎么使用索引呢?

     网上很多的答案告诉我们,如果两个字段都建立了索引,会首先匹配左边的字段,即nick,那么答案就明显了,估计nick和rip可能影响的行数,哪个字段影响的行数少,即区分度大就写在左边。

     到底是不是这样呢?首先我们把nick和rip都设为索引, 用explain来看一下:

在key列,我们可以看到用到nick做为索引,看上去没有什么问题,换个顺序试试:

 还是用nick做为索引,和我们想的不太一样。

到底为什么呢,我试着分析一下,首先我们看这两个字段单独做为条件时结果有多少行:

nick可能影响的行数为7行(rows列不是一个精确值)

rip可能影响的行数为181行,那会不会和这个有关系呢?我们换一个值来看一下:

这次rip可能影响1行,比nick可能影响的行数少,再来看一下两个条件都用到的时候:

这次用到的索引是rip。

那么我们是不是可以得出结论:书写SQL语句的时候,我们不用在意条件的前后顺序,MySQL在查找的时候会进行优化。



  • 2018-08-28 14:19:58

    php如何配置上传较大文件

     在php中判断上传文件的大小,但是文件一但过大,print_r($_FILES);的值就变为null了,有时候大家会遇到这么一个问题,上传小文件 时,PHP能正常获取到,但是文件一超过8M就变为空了,我在做项目的时候,就遇到这样的问题,我刚开始把最大上传文件值改为20M,在PHP.INI里 面。

  • 2018-08-28 15:09:50

    JAVA中MAP值保持顺序不变

    今天在进行JAVA开发过程中,因需要使用MAP来存放数据,同时希望MAP中KEY的顺序与放入顺序保持一致。 在使用HashMap之后,发现KEY的顺序是乱序的,每次打印还不太一样。上网查询资料之后发现:

  • 2018-09-03 13:57:27

    load average 的含义

    一般的进程需要消耗CPU、内存、磁盘I/O、网络I/O等资源,在这种情况下,平均负载就不是单独指的CPU使用情况。即内存、磁盘、网络等因素也可以影响系统的平均负载值。 在单核处理器中,平均负载值为1或者小于1的时候,系统处理进程会非常轻松,即负载很低。当达到3的时候,就会显得很忙,达到5或者8的时候就不能很好的处理进程了(其中5和8目前还是个争议的阈值,为了保守起见,建议选择低的)。

  • 2018-09-05 01:42:03

    git reset 回退以前某个版本及常用命令

    第一个命令只删除所有untracked的文件,如果文件已经被tracked, 修改过的文件不会被回退。而第二个命令把tracked的文件revert到前一个版本,对于untracked的文件(比如编译的临时文件)都不会被删除。

  • 2018-09-08 16:04:25

    Android SQLiteDatabase使用详细教程

    Android提供了创建和是用SQLite数据库的API。SQLiteDatabase代表一个数据库对象,提供了操作数据库的一些方法。在Android的SDK目录下有sqlite3工具,我们可以利用它创建数据库、创建表和执行一些SQL语句。下面是SQLiteDatabase的常用方法。SQLiteDatabase的常用方法方法名称方法表示含义openOrCreateDatabase(Stringpath,SQLiteDatabase.CursorFactoryfactory)