搜索
首页数据库mysql教程深入理解MySQL进阶漂流记(六)

性能优化

索引

索引指向数据库中具体数据所在的一个位置,同事在列上创建一个索引可以排列该列上的信息。当服务器需要访问该信息进行 查询时,就会知晓在什么地方进行查询,因为索引指向有关位置。

如果一个列涉及查询,分组,排序,索引将可以达到提高性能的效果。
带很多重复值的索引不会产生很好的结果。
可以使用表来联合多个非唯一的索引,以便改善性能。
索引越多,性能不一定越好。添加一个索引,并不一定能改善性能。

查询高速缓存

在运行select查询时,MySQL4.x会记录下查询和返回结果。这是通过select每次进行查询时,在一个特殊的高速缓存中保存 结果集实现的。然后,当再次请求服务器做相同的查询时,MySQL将会从高速缓存中检索结果,而不是再次运行该查询。 默认情况下是启动这个性能。

注意,一旦表有变化,使用这个表的高速缓存查询就变成无效,并且将从高速缓存中删除。这样防止查询从旧表上返回 不准确的数据。经常有变化的表,将不会从高速缓存中得到利益。这种情况,可以考虑不使用高速缓存, 可以添加一个选项sql_no_cache来实现。

查询分析

在select查询开始处加上一个explain关键字,将告诉MySQL返回一个图表,说明这个查询如果进行处理, 在这个图表里涉及了查询将访问哪个表的信息以及查询希望返回的行数的信息。这个信息可以用来查看哪些表可以添加索引, 以便加快执行速度,分析瓶颈的位置。

通过查询的显示结果,可以知道什么位置可以添加索引,进行迅速的改正。

优化多表查询

子查询是一个嵌套在另一个select语句中的select语句。子查询经常用来把一个复杂的查询拆分为一些列的逻辑步骤, 或者使用其他查询结果回答一个查询。其结果是不需要执行两个或者更多的单独查询,就可以执行一项包含一项或者多项子查询 的简单查询。

MySQL可以比子查询更好的优化连接,所以如果发现在自己的MySQL服务器上的负载平均值达到了无法接受的高水平,就应该 检验应用程序代码,并试着重写作为连接和连接序列的子查询。

可以通过有效的使用MySQL的集合性能和修改程序来把低效的子查询转变为更为有效的连接。
如果希望避免中间使用嵌套查询,还可以使用基于会话的服务器变量。

使用临时表

MySQL还允许使用create temporary table命令创建临时表。这种表之所以这么称呼,是因为它只针对单一的MySQL会话 过程而存在的,当使用这些表的客户机关闭了与MySQL服务器的连接时,它将自动删除。

因为临时表保存在内存中,所以要比基于磁盘的表明显的快。结果可以有效的作为中间存储区域,以便提高查询实施的速度, 帮助把复杂的的拆分为更简单的部件,或者作为子查询和连接支持的代替。

优化表设计

为了使查询能够更加精炼,需要考虑表设计方面的一些因素。首先,如果经常查询的表会发生很多变化,改进性能的方式就是使用 定长字段,不适用变长字段。虽然使用定长字段将浪费更多的磁盘空间,但是从查询角度看,MySQL处理定长字段比变长字段更快。

改善性能的另一项技术是使用optimize table命令处理经常需要修改的表。经常修改表会导致磁盘碎片,以致花费额外的时间 去读取没有用的空间块,以便得到希望的数据。

在考虑改善性能时,还要检查是否需要针对已经建立的所有表。额外的表意味着性能降低。没有必要合并的表,则应试着匹配连接的 列。

调整服务器设置

如果希望服务器更加有效的运行,最佳解决方案是加大内存空间和使用更大更快的磁盘。但是更多时候,条件是不允许是的。 此时,我们需要一些改进服务器的常规技术。

调整服务器变量,key_buffer_size变量控制MySQL索引缓冲可以使用内存的数量。值越高,索引可以使用的内存越多,性能越好。 一般情况,这个值保持在可使用内存总量的25%到30%。table_cache变量控制表高速缓存可以使用内存的数量,以及在同一时间 内MySQL可以处理表的打开总量。对于有很多数据库和表的非常忙的服务器来说,应该增加这个值,使用set修改。

一旦修改了一个全局服务器变量,关闭服务器之前,这些变量一直存在,但是重启服务器之后,变量恢复默认状态。 所以最好是进行永久性修改。


以上是深入理解MySQL进阶漂流记(六)的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
MySQL如何处理数据复制?MySQL如何处理数据复制?Apr 28, 2025 am 12:25 AM

MySQL通过异步、半同步和组复制三种模式处理数据复制。1)异步复制性能高但可能丢失数据。2)半同步复制提高数据安全性但增加延迟。3)组复制支持多主复制和故障转移,适用于高可用性需求。

您如何使用解释性语句分析查询性能?您如何使用解释性语句分析查询性能?Apr 28, 2025 am 12:24 AM

EXPLAIN语句可用于分析和提升SQL查询性能。1.执行EXPLAIN语句查看查询计划。2.分析输出结果,关注访问类型、索引使用情况和JOIN顺序。3.根据分析结果,创建或调整索引,优化JOIN操作,避免全表扫描,以提升查询效率。

您如何备份并还原MySQL数据库?您如何备份并还原MySQL数据库?Apr 28, 2025 am 12:23 AM

使用mysqldump进行逻辑备份和MySQLEnterpriseBackup进行热备份是备份MySQL数据库的有效方法。1.使用mysqldump备份数据库:mysqldump-uroot-pmydatabase>mydatabase_backup.sql。2.使用MySQLEnterpriseBackup进行热备份:mysqlbackup--user=root--password=password--backup-dir=/path/to/backupbackup。恢复时,使用相应的命

MySQL中慢速查询的常见原因是什么?MySQL中慢速查询的常见原因是什么?Apr 28, 2025 am 12:18 AM

MySQL慢查询的主要原因包括索引缺失或不当使用、查询复杂度、数据量过大和硬件资源不足。优化建议包括:1.创建合适的索引;2.优化查询语句;3.使用分表分区技术;4.适当升级硬件。

MySQL中有什么看法?MySQL中有什么看法?Apr 28, 2025 am 12:04 AM

MySQL视图是基于SQL查询结果的虚拟表,不存储数据。1)视图简化复杂查询,2)增强数据安全性,3)维护数据一致性。视图是数据库中的存储查询,可像表一样使用,但数据动态生成。

MySQL和其他SQL方言之间的语法有什么区别?MySQL和其他SQL方言之间的语法有什么区别?Apr 27, 2025 am 12:26 AM

mysqldiffersfromothersqldialectsinsyntaxforlimit,自动启动,弦乐范围,子征服和表面上分析。1)MySqluessLipslimit,whilesqlserverusestopopandoraclesrontersrontsrontsrontsronnum.2)

什么是mysql分区?什么是mysql分区?Apr 27, 2025 am 12:23 AM

MySQL分区能提升性能和简化维护。1)通过按特定标准(如日期范围)将大表分成小块,2)物理上将数据分成独立文件,3)查询时MySQL可专注于相关分区,4)查询优化器可跳过不相关分区,5)选择合适的分区策略并定期维护是关键。

您如何在MySQL中授予和撤销特权?您如何在MySQL中授予和撤销特权?Apr 27, 2025 am 12:21 AM

在MySQL中,如何授予和撤销权限?1.使用GRANT语句授予权限,如GRANTALLPRIVILEGESONdatabase_name.TO'username'@'host';2.使用REVOKE语句撤销权限,如REVOKEALLPRIVILEGESONdatabase_name.FROM'username'@'host',确保及时沟通权限变更。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器