Mysql系列(五)索引功能

索引是一种特殊的文件(innodb 数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。索引不是万能的,索引可以加快数据检索操作,但会使数据修改操作变慢。每修改数据记录,索引就必须刷新一次。为了在某种程度上弥补这一缺陷,许多 sql 命令都有一个 delay_key_write 项。这个选项的作用是暂时制止 mysql 在该命令每插入一条新记录和每修改一条现有之后立刻对索引进行刷新,对索引的刷新将等到全部记录插入/修改完毕之后再进行。在需要把许多新记录插入某个数据表的场合,delay_key_write 选项的作用将非常明显。另外,索引还会在硬盘上占用相当大的空间。因此应该只为最经常查询和最经常排序的数据列建立索引。注意,如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果。

从理论上讲,完全可以为数据表里的每个字段分别建一个索引,但 MySQL 把同一个数据表里的索引总数限制为16个。

1.InnoDB 数据表的索引

与 InnoDB数据表相比,在 InnoDB 数据表上,索引对 InnoDB 数据表的重要性要大得多。在 InnoDB 数据表上,索引不仅会在搜索数据记录时发挥作用,还是数据行级锁定机制的苊、基础。“数据行级锁定”的意思是指在事务操作的执行过程中锁定正在被处理的个别记录,不让其他用户进行访问。这种锁定将影响到(但不限于)SELECT、LOCKINSHAREMODE、SELECT、FORUPDATE 命令以及 INSERT、UPDATE 和 DELETE 命令。出于效率方面的考虑,InnoDB 数据表的数据行级锁定实际发生在它们的索引上,而不是数据表自身上。显然,数据行级锁定机制只有在有关的数据表有一个合适的索引可供锁定的时候才能发挥效力。

2.限制

如果 WHERE 子句的查询条件里有不等号(WHERE coloum !=),MySQL 将无法使用索引。类似地,如果 WHERE 子句的查询条件里使用了函数(WHERE DAY(column)=),MySQL 也将无法使用索引。在 JOIN 操作中(需要从多个数据表提取数据时),MySQL 只有在主键和外键的数据类型相同时才能使用索引。

如果 WHERE 子句的查询条件里使用比较操作符 LIKE 和 REGEXP,MySQL 只有在搜索模板的第一个字符不是通配符的情况下才能使用索引。比如说,如果查询条件是 LIKE ‘abc%‘,MySQL 将使用索引;如果查询条件是 LIKE ‘%abc’,MySQL 将不使用索引。

在 ORDER BY 操作中,MySQL 只有在排序条件不是一个查询条件表达式的情况下才使用索引。(虽然如此,在涉及多个数据表查询里,即使有索引可用,那些索引在加快 ORDER BY 方面也没什么作用)。如果某个数据列里包含许多重复的值,就算为它建立了索引也不会有很好的效果。比如说,如果某个数据列里包含的净是些诸如 “0/1” 或 “Y/N” 等值,就没有必要为它创建一个索引。

索引类别

1.普通索引

普通索引(由关键字 KEY 或 INDEX 定义的索引)的唯一任务是加快对数据的访问速度。因此,应该只为那些最经常出现在查询条件(WHERE column =)或排序条件(ORDER BY column)中的数据列创建索引。只要有可能,就应该选择一个数据最整齐、最紧凑的数据列(如一个整数类型的数据列)来创建索引。

2.唯一索引

普通索引允许被索引的数据列包含重复的值。比如说,因为人有可能同名,所以同一个姓名在同一个“员工个人资料”数据表里可能出现两次或更多次。

如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字UNIQUE 把它定义为一个唯一索引。这么做的好处:一是简化了 MySQL 对这个索引的管理工作,这个索引也因此而变得更有效率;二是 MySQL 会在有新记录插入数据表时,自动检查新记录的这个字段的值是否已经在某个记录的这个字段里出现过了;如果是,MySQL 将拒绝插入那条新记录。也就是说,唯一索引可以保证数据记录的唯一性。事实上,在许多场合,人们创建唯一索引的目的往往不是为了提高访问速度,而只是为了避免数据出现重复。

3.主索引

在前面已经反复多次强调过:必须为主键字段创建一个索引,这个索引就是所谓的“主索引”。主索引与唯一索引的唯一区别是:前者在定义时使用的关键字是 PRIMARY 而不是 UNIQUE。

4.外键索引

如果为某个外键字段定义了一个外键约束条件,MySQL 就会定义一个内部索引来帮助自己以最有效率的方式去管理和使用外键约束条件。

5.复合索引

索引可以覆盖多个数据列,如像 INDEX (columnA, columnB) 索引。这种索引的特点是 MySQL 可以有选择地使用一个这样的索引。如果查询操作只需要用到 columnA 数据列上的一个索引,就可以使用复合索引 INDEX(columnA, columnB)。不过,这种用法仅适用于在复合索引中排列在前的数据列组合。比如说,INDEX (A,B,C) 可以当做 A 或 (A,B) 的索引来使用,但不能当做 B、C 或 (B,C) 的索引来使用。

爱克网络企业网站建设系统 No.090730 爱克网络企业网站建设系统 No.090730

系统特点:功能简洁实用。目前互联网上最简洁的企业网站建设系统!原创程序代码。非网络一般下载后修改的代码。更安全。速度快!界面模版分离。原创的分离思路,完全不同于其他方式,不一样的简单感受!搜索引擎优化。做了基础的seo优化。对搜索引擎更友好系统功能关于我们:介绍企业介绍类信息,可自由添加多个介绍栏目!资讯中心:公司或行业资讯类内容展示。可自由添加多个资讯内容!产品展示:支持类别设置,可添加产品图片

爱克网络企业网站建设系统 No.090730 0 查看详情 爱克网络企业网站建设系统 No.090730

索引长度

在为 CHAR 和 VARCHAR 类型的数据列定义索引时,可以把索引的长度限制为一个给定的字符个数(这个数字必须小于这个字段所允许的最大字符个数)。这么做的好处是可以生成一个尺寸比较小、检索速度却比较快的索引文件。在绝大多数应用里,数据库中的字符串数据大都以各种各样的名字为主,把索引的长度设置为10~15 个字符已经足以把搜索范围缩小到很少的几条数据记录了。在为 BLOB 和 TEXT 类型的数据列创建索引时,必须对索引的长度做出限制;MySQL 所允许的最大索引全文索引文本字段上的普通索引只能加快对出现在字段内容最前面的字符串(也就是字段内容开头的字符)进行检索操作。如果字段里存放的是由几个、甚至是多个单词构成的较大段文字,普通索引就没什么作用了。这种检索往往以的形式出现,这对 MySQL 来说很复杂,如果需要处理的数据量很大,响应时间就会很长。

这类场合正是全文索引(full-textindex)可以大显身手的地方。在生成这种类型的索引时,MySQL 将把在文本中出现的所有单词创建为一份清单,查询操作将根据这份清单去检索有关的数据记录。全文索引即可以随数据表一同创建,也可以等日后有必要时再使用下面这条命令添加:

ALTER TABLE tablename ADD FULLTEXT(column1,column2)有了全文索引,就可以用 SELECT 查询命令去检索那些包含着一个或多个给定单词的数据记录了。下面是这类查询命令的基本语法:

SELECT * FROM tablename

WHERE MATCH (column1,column2) AGAINST(‘word1′,’word2′,’word3’)

上面这条命令将把 column1 和 column2 字段里有 word1、word2 和 word3 的数据记录全部查询出来。

注解:InnoDB 数据表不支持全文索引。

查询和索引

只有当数据库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值。如果在测试数据库里只有几百条数据记录,它们往往在执行完第一条查询命令之后就被全部加载到内存里,这将使后续的查询命令都执行得非常快–不管有没有使用索引。只有当数据库里的记录超过了 1000 条、数据总量也超过了 MySQL 服务器上的内存总量时,数据库的性能测试结果才有意义。

在不确定应该在哪些数据列上创建索引的时候,人们从 EXPLAIN SELECT 命令那里往往可以获得一些帮助。这其实只是简单地给一条普通的 SELECT 命令加一个 EXPLAIN 关键字作为前缀而已。有了这个关键字,MySQL 将不是去执行那条 SELECT 命令,而是去对它进行分析。MySQL 将以表格的形式把查询的执行过程和用到的索引等信息列出来。

在 EXPLAIN 命令的输出结果里,第1列是从数据库读取的数据表的名字,它们按被读取的先后顺序排列。type列指定了本数据表与其它数据表之间的关联关系(JOIN)。在各种类型的关联关系当中,效率最高的是 system,然后依次是 const、eq_ref、ref、range、index 和 All(All 的意思是:对应于上一级数据表里的每一条记录,这个数据表里的所有记录都必须被读取一遍——这种情况往往可以用一索引来避免)。

possible_keys 数据列给出了 MySQL 在搜索数据记录时可选用的各个索引。key 数据列是 MySQL 实际选用的索引,这个索引按字节计算的长度在 key_len 数据列里给出。比如说,对于一个 INTEGER 数据列的索引,这个字节长度将是4。如果用到了复合索引,在 key_len 数据列里还可以看到 MySQL 具体使用了它的哪些部分。作为一般规律,key_len 数据列里的值越小越好。

ref 数据列给出了关联关系中另一个数据表里的数据列的名字。row 数据列是 MySQL 在执行这个查询时预计会从这个数据表里读出的数据行的个数。row 数据列里的所有数字的乘积可以大致了解这个查询需要处理多少组合。

最后,extra 数据列提供了与 JOIN 操作有关的更多信息,比如说,如果 MySQL 在执行这个查询时必须创建一个临时数据表,就会在 extra 列看到 usingtemporary 字样。

以上就是Mysql系列(五)索引功能的内容,更多相关内容请关注PHP中文网(www.php.cn)!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/802309.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月26日 18:37:53
下一篇 2025年11月26日 18:43:33

相关推荐

  • PHP字符串数字比较陷阱:八进制字面量与松散比较解析及代码优化实践

    本文深入探讨了PHP在处理以0开头的字符串与数字字面量进行松散比较时可能遇到的陷阱,特别是当遇到08、09等无效八进制字面量时,PHP的类型转换机制如何导致意外结果。文章将详细分析这一问题,并提供使用字符串进行精确比较、利用关联数组优化数据映射以及分离业务逻辑与视图的专业解决方案,旨在帮助开发者编写…

    好文分享 2025年12月10日
    000
  • PHP字符串与数字比较陷阱:以高速公路计算器为例解析八进制字面量问题

    本教程深入探讨PHP中字符串与数字比较时可能遇到的常见陷阱,特别是当数字以0开头时引发的八进制字面量解析问题。我们将通过一个高速公路收费计算器的实例,详细分析”08″和08等值在比较中的差异,并提供使用字符串比较、映射表和结构化控制流的优化解决方案,以提升代码的健壮性和可读性…

    2025年12月10日
    000
  • 在多个相似目录中执行 Bash 命令的实用技巧

    本文介绍如何使用 Bash 脚本在多个相似目录中高效执行相同的命令。通过循环结构,避免重复编写相似代码,提高脚本的可维护性和可读性。我们将提供一个简单易懂的示例,展示如何利用 for 循环和通配符来简化任务,并提供一些额外的注意事项,帮助您编写更健壮的脚本。 在日常的系统管理和自动化任务中,我们经常…

    2025年12月10日
    000
  • 优化Bash脚本:在相似目录中高效批量执行命令

    本文介绍如何利用Bash脚本中的for循环,高效地在多个具有相似结构的不同目录下批量执行同一命令,避免重复冗余的代码。通过通配符匹配目录路径,结合循环结构,可以极大地简化脚本,提升可维护性和执行效率。适用于自动化运维、网站管理等场景,实现代码的简洁与高效。 自动化批量命令执行的挑战 在日常的系统管理…

    2025年12月10日
    000
  • 批量执行命令:使用 Bash 循环处理相似目录

    本文介绍如何使用 Bash 循环来简化在多个相似目录中执行相同命令的操作。通过 for 循环和通配符,可以避免重复编写相似的命令,提高脚本的效率和可维护性。文章将提供具体代码示例,并讨论相关的注意事项,帮助读者更好地理解和应用这种方法。 在日常的系统管理和自动化任务中,经常会遇到需要在多个结构相似的…

    2025年12月10日
    000
  • Bash脚本:在多个相似目录下高效执行命令

    本文详细阐述了如何利用Bash脚本高效地在多个结构相似的目录下执行重复命令。通过结合强大的glob模式匹配和for循环结构,用户可以显著简化脚本代码,避免冗余,提高可维护性。教程将涵盖核心实现方法、关键语法解析,并提供注意事项,帮助读者优化批量任务处理流程,尤其适用于Web应用等场景下的定时任务自动…

    2025年12月10日
    000
  • 自动化多相似目录下的命令执行:Bash脚本优化实践

    本教程探讨了如何高效地在多个具有相似路径结构的目录下执行重复命令,避免手动编写大量重复代码。核心解决方案是利用Bash的for循环结合通配符,实现命令的批量自动化执行,从而提高脚本的简洁性和可维护性。 引言:重复命令执行的痛点 在日常的系统管理和自动化任务中,我们经常会遇到需要在多个具有相似目录结构…

    2025年12月10日
    000
  • PHP表单提交后刷新页面避免重复提交的解决方案

    第一段引用上面的摘要本文旨在解决PHP表单提交后,刷新页面导致重复提交的问题。通过分析问题产生的原因,提供基于JavaScript的解决方案,防止用户在刷新页面时意外地再次提交表单数据,从而保证数据的准确性和一致性。 问题分析 在PHP Web开发中,当用户提交表单后,如果直接刷新页面,浏览器通常会…

    2025年12月10日
    000
  • PHP表单提交后刷新页面避免重复提交及结果显示

    本文旨在解决PHP表单提交后,刷新页面时浏览器提示“确认重新提交表单”以及页面重复显示结果的问题。通过使用JavaScript防止表单重复提交,并结合PHP代码处理表单数据,确保用户体验的流畅性,避免不必要的重复操作。本文提供了一种无需重定向的解决方案,保持页面状态的同时避免重复提交。 在PHP开发…

    2025年12月10日
    000
  • 解决VS Code中PHP Slim项目Xdebug调试失效问题

    在使用VS Code和Xdebug调试PHP Slim框架项目时,开发者常遇到断点无法生效的问题,尤其是在使用Composer创建的Slim骨架项目和PHP内置Web服务器时。本文将详细指导如何通过优化launch.json配置,确保Xdebug能够正确捕获Slim项目的请求,从而实现高效的断点调试…

    2025年12月10日
    000
  • 使用 VS Code 和 Xdebug 调试 Slim 框架项目

    本文档旨在帮助 PHP 初学者使用 Visual Studio Code (VS Code) 和 Xdebug 调试基于 Slim 框架构建的 API 项目。我们将详细介绍如何配置 VS Code 的 launch.json 文件,以便在 Slim 项目中设置断点并进行调试,解决断点失效的问题,确保…

    2025年12月10日
    000
  • VS Code中PHP Slim项目Xdebug调试配置与断点无效问题解决方案

    本文详细介绍了在VS Code中调试PHP Slim框架项目的Xdebug配置方法,特别针对使用composer start启动的Slim Skeleton项目断点无效的问题。核心解决方案是优化launch.json文件中的cwd路径和内置Web服务器的端口配置,确保Xdebug正确与PHP进程通信…

    2025年12月10日
    000
  • Laravel Eloquent 高效条件日期过滤:优化可选日期范围查询

    本文旨在解决在 Laravel 应用中处理可选日期范围查询的常见问题。通过对比在 PHP 集合上过滤数据与在数据库层面进行条件查询的效率差异,重点介绍了如何利用 Eloquent 查询构建器的 when() 方法,简洁、高效地实现基于可选开始日期和结束日期的数据库过滤,从而提升数据检索的性能和代码的…

    2025年12月10日
    000
  • PHP file() 函数读取文件时换行符的影响及处理方法

    本文深入探讨了PHP中使用 file() 函数读取文件内容并与直接定义的数组进行比较时,in_array() 函数行为差异的原因。核心问题在于 file() 函数默认保留了每行末尾的换行符,导致字符串匹配失败。教程将详细介绍这一机制,并提供通过 array_map(‘trim&#8217…

    2025年12月10日
    000
  • 解决 hMailServer 无法从 localhost 接收邮件的问题

    本文档旨在解决在 Windows 365 Business Cloud 上搭建 hMailServer 时,遇到的无法从 localhost 接收邮件的问题。通过检查和修改 sendmail.ini 配置文件,确保 PHP 的 mail() 函数能够正确地将邮件发送到 hMailServer 监听的…

    2025年12月10日
    000
  • hMailServer与PHP本地邮件发送指南:解决localhost收件问题

    本教程详细指导如何在Windows环境下配置hMailServer、XAMPP及PHP,以实现本地主机间的邮件发送与接收。重点解决PHP mail()函数发送邮件到hMailServer收件箱不成功的问题,核心在于正确配置sendmail.ini中的smtp_server参数指向localhost,…

    2025年12月10日
    000
  • hMailServer与PHP Localhost邮件收发配置指南

    本教程详细指导如何在Windows环境下配置hMailServer与XAMPP/PHP实现本地邮件收发。针对PHP mail() 函数发送邮件后无法送达hMailServer收件箱的问题,核心解决方案是正确配置XAMPP自带的sendmail.ini文件中的smtp_server参数为localho…

    2025年12月10日
    000
  • hMailServer无法从localhost接收邮件的解决方案

    摘要 本文旨在解决在Windows 365 Business Cloud上使用hMailServer时,无法从localhost接收邮件的问题。通常,这是由于PHP配置不正确,导致邮件无法正确路由到hMailServer。通过检查和修改sendmail.ini配置文件中的SMTP服务器设置,确保其指…

    2025年12月10日
    000
  • PHP 嵌套循环实现素数查找教程

    本文旨在指导初学者使用 PHP 中的嵌套循环来查找指定范围内的素数。我们将通过一个实际的示例,详细讲解如何使用嵌套循环判断一个数是否为素数,并最终输出指定范围内的所有素数。文章将包含完整的代码示例,并对关键步骤进行解释,帮助读者理解素数的概念以及如何用 PHP 代码实现。 素数概念 素数是指在大于 …

    2025年12月10日
    000
  • PHP 嵌套循环实现素数判断与列表

    本教程详细介绍了如何使用 PHP 嵌套循环来查找并列出指定范围内的所有素数。文章从素数的基本概念入手,逐步讲解了使用嵌套循环进行素数判断的逻辑,并重点分析了初学者常犯的错误——状态标志未重置问题。通过提供一个优化后的代码示例,教程展示了如何正确地实现素数筛选,包括利用 break 语句提升效率,旨在…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信