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

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

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

优化MySQL数据库查询中有三种方案,今天我们就和大家一起分享这三种具体的操作方案,我们大家都知道数据库应用(如MySQL(和PHP搭配之更佳组合))即意味着对工具的实际操作与使用。

使用索引、使用EXPLAIN分析查询以及调整MySQL(和PHP搭配之更佳组合)的内部配置可达到优化查询的目的。

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

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

优化MySQL数据库查询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搭配之更佳组合)不得不每次都为这些额外的工作重新建立索引。另一方面,避免对表的每一域做索引同样不是一个非常好的主意,因为在提高插入记录的速度时,导致查询操作的速度减慢。这就需要找到一个平衡点,比如在设计索引系统时,考虑表的主要功能(数据修复及编辑)不失为一种明智的选择。

优化MySQL数据库查询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%!自然,数据库资源的查询速度更快,效率更高。

优化MySQL数据库查询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/21199.html

分享给朋友:

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

各个都很实用:windows 7系统电脑日常小技巧

各个都很实用:windows 7系统电脑日常小技巧

在使用Windows 7的时候很多用户对于系统的很多功能并不是很了解,也正是因为这样的不了解导致很多用户在使用Win 之后并不能体验Windows 7的功能便携和强大功能,导致很多用户对于Windows 7的认识还是比较模糊,不过为了让更多的朋友了解Windows 7的特点和便携应用,今天就为大家汇...

微软今天正式停止对windows 7的主流支持

微软今天正式停止对windows 7的主流支持

北京时间1月13日消息,根据计划,微软将于2015年1月13日正式结束对Windows 7SP1的“主流支持”,而这也标志着“扩展支持”阶段的开始,这个阶段将于2020年1月14日结束。 2013年10月份,微软终止销售独立的Windows 7系统安装包,并要求制造商于2014年10月份停止生...

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

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

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

windows 7如何给c盘扩容 图解windows 7 64位系统C盘扩容方法(自

windows 7如何给c盘扩容 图解windows 7 64位系统C盘扩容方法(自

用Windows 7久了,C盘越来越大,原来50G的空间基本用完了,又不想重装系统,就想着能不能直接扩容。 在网上搜了半天,看了无数教程,都写得不明不白的,结合了几篇教程才终于搞明白。 重新总结一下,方便有需要的人。 所用软件: http://www.jb51.net/softs/57895...

windows 7旗舰版系统提示应用程序错误代码0xc0000409的故障原因

windows 7旗舰版系统提示应用程序错误代码0xc0000409的故障原因

问题现象,具体如下所示:  故障分析: 一般来说,出现这种情况是因为电脑误删系统文件或者是系统文件被顽固木马破坏。       解决方法: 1、下载360安全卫士,找到里面的急救箱开始急救,然后进行修复,完成后重新启动; 2、下载瑞...

windows 7系统开机提示Windows驱动器未就绪的故障原因及解决方法

windows 7系统开机提示Windows驱动器未就绪的故障原因及解决方法

 故障分析: 主要原因应该是不存在软盘驱动器或驱动器未安装,找到故障原因后,Windows 7 32位系统只要将软盘驱动器禁用就可以了。 解决措施: 1、右键点击计算机,选择管理,打开计算机管理窗口; 2、在计算机管理中,找到设备管理器,在右边的软盘控制器中右击,选择卸载即可。 以...