0

0

深入理解MySQL进阶漂流记(六)

黄舟

黄舟

发布时间:2017-03-08 13:57:52

|

1342人浏览过

|

来源于php中文网

原创

性能优化

索引

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

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

查询高速缓存

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

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

查询分析

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

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

优化多表查询

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

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

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

Haiper
Haiper

一个感知模型驱动的AI视频生成和重绘工具,提供文字转视频、图片动画化、视频重绘等功能

下载
使用临时表

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

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

优化表设计

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

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

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

调整服务器设置

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

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

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

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

4

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

3

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 778人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号