当前位置:首页 > 系统运维 > 正文内容

MySQL数据库查询优化的3个好用方案

a8116255316年前 (2010-06-10)系统运维8

此文章主要向大家描述的是三个好用的 *** 来对MySQL数据库查询进行优化,我们大家在实际操作中有时候会觉得MySQL数据库查询在某些应用中好像有点“落伍”了,那么如何对其进行改造呢?

在优化查询中,数据库应用(如MySQL(和PHP搭配之更佳组合))即意味着对工具的操作与使用。使用索引、使用EXPLAIN分析查询以及调整MySQL(和PHP搭配之更佳组合)的内部配置可达到优化查询的目的。

任何一位数据库程序员都会有这样的体会:高通信量的数据库驱动程序中,一条糟糕的SQL查询语句可对整个应用程序的运行产生严重的影响,其不仅消耗掉更多的数据库时间,且它将对其他应用组件产生影响。

如同其它学科,优化查询性能很大程度上决定于开发者的直觉。幸运的是,像MySQL(和PHP搭配之更佳组合)这样的数据库自带有一些协助工具。该篇文章简要讨论诸多工具之三种:使用索引,使用EXPLAIN分析查询以及调整MySQL(和PHP搭配之更佳组合)的内部配置。

数据库查询优化1: 使用索引

MySQL(和PHP搭配之更佳组合)允许对数据库表进行索引,以此能迅速查找记录,而无需一开始就扫描整个表,由此显着地加快查询速度。每个表最多可以做到16个索引,此外MySQL(和PHP搭配之更佳组合)还支持多列索引及全文检索。

给表添加一个索引非常简单,只需调用一个CREATE INDEX命令并为索引指定它的域即可。列表A给出了一个例子:

列表 A

MySQL(和PHP搭配之更佳组合)> CREATE INDEX idx_username ON users(username);  Query OK, 1 row affected (0.15 sec)  Records: 1 Duplicates: 0 Warnings: 0 

这里,对users表的username域做索引,以确保在WHERE或者HAVING子句中引用这一域的SELECT查询语句运行速度比没有添加索引时要快。通过SHOW INDEX命令可以查看索引已被创建(列表B)。

列表 B

MySQL(和PHP搭配之更佳组合)> SHOW INDEX FROM users;  --------------+-------------+-----------+-------------+----------+--------+------+------------+---------+  | Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment |  --------------+-------------+-----------+-------------+----------+--------+------+------------+---------+  | users | 1 | idx_username | 1 | username | A | NULL | NULL | NULL | YES |  *** REE | |  --------------+-------------+-----------+-------------+----------+--------+------+------------+---------+  1 row in set (0.00 sec) 

值得注意的是:索引就像一把双刃剑。对表的每一域做索引通常没有必要,且很可能导致运行速度减慢,因为向表中插入或修改数据时,MySQL(和PHP搭配之更佳组合)不得不每次都为这些额外的工作重新建立索引。

另一方面,避免对表的每一域做索引同样不是一个非常好的主意,因为在提高插入记录的速度时,导致查询操作的速度减慢。这就需要找到一个平衡点,比如在设计索引系统时,考虑表的主要功能(数据修复及编辑)不失为一种明智的选择。

数据库查询优化2: 优化查询性能

在分析查询性能时,考虑EXPLAIN关键字同样很管用。EXPLAIN关键字一般放在SELECT查询语句的前面,用于描述MySQL(和PHP搭配之更佳组合)如何执行查询操作、以及MySQL(和PHP搭配之更佳组合)成功返回结果集需要执行的行数。下面的一个简单例子可以说明(列表C)这一过程:

列表 C

MySQL(和PHP搭配之更佳组合)> EXPLAIN SELECT city.name, city.district FROM city, country WHERE city.countrycode = country.code AND country.code = 'IND';  +----+-------------+---------+-------+---------------+---------+---------+-------+------+-------------+  | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |  +----+-------------+---------+-------+---------------+---------+---------+-------+------+-------------+ 

| 1 | SIMPLE | country | const | Prima(最完善的虚拟主机管理系统)RY | Prima(最完善的虚拟主机管理系统)RY | 3 | const | 1 | Using index |

| 1 | SIMPLE | city | ALL | NULL | NULL | NULL | NULL | 4079 | Using where |  +----+-------------+---------+-------+---------------+---------+---------+-------+------+-------------+ 

2 rows in set (0.00 sec)这里查询是基于两个表连接。EXPLAIN关键字描述了MySQL(和PHP搭配之更佳组合)是如何处理连接这两个表。必须清楚的是,当前设计要求MySQL(和PHP搭配之更佳组合)处理的是country表中的一条记录以及city表中的整个4019条记录。这就意味着,还可使用其他的优化技巧改进其查询 *** 。例如,给city表添加如下索引(列表D):

列表 D

MySQL(和PHP搭配之更佳组合)> CREATE INDEX idx_ccode ON city(countrycode);  Query OK, 4079 rows affected (0.15 sec)  Records: 4079 Duplicates: 0 Warnings: 0 

现在,当我们重新使用EXPLAIN关键字进行查询时,我们看到的是一个显着的改进(列表E):

列表 E

MySQL(和PHP搭配之更佳组合)> EXPLAIN SELECT city.name, city.district FROM city, country WHERE city.countrycode = country.code AND country.code = 'IND';  +----+-------------+---------+-------+---------------+-----------+---------+-------+------+-------------+  | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |  +----+-------------+---------+-------+---------------+-----------+---------+-------+------+-------------+  | 1 | SIMPLE | country | const | Prima(最完善的虚拟主机管理系统)RY | Prima(最完善的虚拟主机管理系统)RY | 3 | const | 1 | Using index |  | 1 | SIMPLE | city | ref | idx_ccode | idx_ccode | 3 | const | 333 | Using where |  +----+-------------+---------+-------+---------------+-----------+---------+-------+------+-------------+  2 rows in set (0.01 sec) 

在这个例子中,MySQL(和PHP搭配之更佳组合)现在只需要扫描city表中的333条记录就可产生一个结果集,其扫描记录数几乎减少了90%!自然,数据库资源的查询速度更快,效率更高。

数据库查询优化3: 调整内部变量

MySQL(和PHP搭配之更佳组合)是如此的开放,所以可轻松地进一步调整其缺省设置以获得更优的性能及稳定性。需要优化的一些关键变量如下:

改变索引缓冲区长度(key_buffer)

一般,该变量控制缓冲区的长度在处理索引表(读/写操作)时使用。MySQL(和PHP搭配之更佳组合)使用手册指出该变量可以不断增加以确保索引表的更佳性能,并推荐使用与系统内存25%的大小作为该变量的值。这是MySQL(和PHP搭配之更佳组合)十分重要的配置变量之一,如果你对优化和提高系统性能有兴趣,可以从改变key_buffer_size变量的值开始。

改变表长(read_buffer_size)

当一个查询不断地扫描某一个表,MySQL(和PHP搭配之更佳组合)会为它分配一段内存缓冲区。read_buffer_size变量控制这一缓冲区的大小。如果你认为连续扫描进行得太慢,可以通过增加该变量值以及内存缓冲区大小提高其性能。

设定打开表的数目的更大值(table_cache)

该变量控制MySQL(和PHP搭配之更佳组合)在任何时候打开表的更大数目,由此能控制服务器响应输入请求的能力。它跟max_connections变量密切相关,增加table_cache值可使MySQL(和PHP搭配之更佳组合)打开更多的表,就如增加max_connections值可增加连接数一样。当收到大量不同数据库及表的请求时,可以考虑改变这一值的大小。

对缓长查询设定一个时间限制(long_query_time)

MySQL(和PHP搭配之更佳组合)带有“慢查询日志”,它会自动地记录所有的在一个特定的时间范围内尚未结束的查询。这个日志对于跟踪那些低效率或者行为不端的查询以及寻找优化对象都非常有用。long_query_time变量控制这一更大时间限定,以秒为单位。

以上讨论并给出用于分析和优化SQL查询的三种工具的使用 *** ,以此提高你的应用程序性能。使用它们快乐地优化吧!

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/20990.html

分享给朋友:

“MySQL数据库查询优化的3个好用方案” 的相关文章

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

很多使用Windows 7系统的朋友都想小编反应,假如暂停使用电脑,鼠标会出现停顿现象,这是怎么回事呢 该怎么解决呢 下面就和小编一起去看下Windows 7 usb鼠标停顿的解决方法吧。 由于Windows 7系统中有一项USB选择性暂停造成的。这项设置主要为了节电,当他检测到用户没有对系统进行...

windows 7/8.1正在启动windows时间长的解决方法

windows 7/8.1正在启动windows时间长的解决方法

正在启动windows时间长怎么办 小编带来了Windows 7/8.1正在启动windows时间长解决方法,假如有朋友在安装完Windows系统之后一直停留在“正在启动windows”的话,不妨试一试下文的方法哦~ 原因:Windows 7/8.1不完全支持UEFI,需要CSM(Comp...

如何设置Win 7通知栏重新显示电源按钮

如何设置Win 7通知栏重新显示电源按钮

有些使用本本的朋友可能会发现,右下角通知栏区域会无法显示电源按钮,导致在插上电源或者是使用电池的时候都无法进行区分。造成这种情况大部分都是因为使用了第三方修改过的系统版本或者对于系统优化过度,所以今天就来解决这个问题。 第一步:在开始菜单的搜索窗口输入“gpedit.msc”,进入组策略编辑器,依...

Windows7开机后出现黑一下屏性能降低

Windows7开机后出现黑一下屏性能降低

打开IE浏览器的时候、聊QQ的时候、玩游戏的时候… … 这到底是谁惹的祸呢? 很多人都知道Windows 7桌面特效全部开启会使系统性能降低,那到底是哪个特效导致的这一情况呢? 解决办法: 右键计算机,高级系统设置-性能-设置-关闭”任务栏和开始菜单使用动画“和”最大化和最小化动态显示窗口“...

Win 7系统中其他声音正常但酷狗音乐没声音怎么回事

Win 7系统中其他声音正常但酷狗音乐没声音怎么回事

故障现象: Windows 7酷狗软件无声音,系统声音正常。 原因分析: 1. 查看酷狗软件设置 2. 查看系统设置 解决方案: 1. Windows 7操作方法 如图:查看是否处于禁音状态   Windows 7系统声音正常酷狗音乐无声音 2. 查看设置音频输出是否...

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。 1、在开始搜索框中键入“regedit”,按回车键打开注册表编辑器。 2、依次定位到以下分支:HKEY_CLASSES_ROOTlnkfile。 3、在lnkfile项上鼠标右键单击“新建”——“字符串值”。...