郑州北大青鸟:MySQL如何优化 WHERE 子句
我们河南北大青鸟郑州翔天中心专业的电脑培训学校,今天给大家分享的是有关数据库的相关知识:MySQL如何优化 WHERE 子句。
MySQL的一些优化做法如下:
去除不必要的括号:
((a AND b) AND c OR (((a AND b) AND (c AND d))))
-%26gt; (a AND b AND c) OR (a AND b AND c AND d)
展开常量:
(a -%26gt; b%26gt;5 AND b=c AND a=5
去除常量条件(在展开常量时需要):
(B%26gt;=5 AND B=5) OR (B=6 AND 5=5) OR (B=7 AND 5=6)
-%26gt; B=5 OR B=6
常量表达示在索引中只计算一次
在单独一个表上做 COUNT(*) 而不使用 WHERE 时, 对于 MyISAM 和 HEAP 表就会直接从表信息中检索结果。在单独一个表上做任何表 NOT NULL 达式查询时也是这样做。
预先探测无效的常量表达式。MySQL会快速探测一些不可能的 SELECT 语句并且不返回任何记录。
当没用 GROUP BY 或分组函数时,HAVING 和 WHERE 合并(COUNT(), MIN() 等也是如此)。
为表连接中的每个表构造一个简洁的 WHERE 语句,以得到更快的 WHERE 计算值并且尽快跳过记录
查询中所有的常量表都会比其他表更早读取。一个常量表符合以下几个条件:
空表或者只有一条记录。
与在一个 UNIQUE 索引、或一个 PRIMARY KEY 的 WHERE 子句一起使用的表,这里所有的索引部分和常数表达式做比较并且索引部分被定义为 NOT NULL。
以下的几个表都会被当成常量表:
SELECT * FROM t WHERE primary_key=1;
SELECT * FROM t1,t2
WHERE t1.primary_key=1 AND t2.primary_key=t1.id;
MySQL会进各种可能找到表连接最好的连接方法。 如果在 ORDER BY 和 GROUP BY 子句中的所有字段都来自同一个表的话,那么在连接时这个表就会优先处理。
如果有 ORDER BY 子句和一个不同的 GROUP BY 子句,或者如果 ORDER BY 或 GROUP BY 中的字段都来自其他的表而非连接顺序中的第一个表的话,就会创建一个临时表了。
如果使用 SQL_SMALL_RESULT,MySQL就会使用内存临时表了。
所有的表索引都会查询,最好的情况就是所有的索引都会被用到,除非优化程序认为全表扫描的效率更高。同时,数据表扫描是基于判断最好的索引范围超过数据表的30%。 现在,优化程序复杂多了,它基于对一些附加因素的估计,例如表大小,记录总数,I/O块大小,因此就不能根据一个固定的百分比来决定是选择使用索引还是直接扫描数据表。
在某些情况下,MySQL可以直接从索引中取得记录而无需查询数据文件。如果所有在索引中使用的字段都是数字类型的话,只需要用索引树就能完成查询。
每条记录输出之前,那些没有匹配 HAVING 子句的就会被跳过。
以下几个查询速度非常快:
SELECT COUNT(*) FROM tbl_name;
SELECT MIN(key_part1),MAX(key_part1) FROM tbl_name;
SELECT MAX(key_part2) FROM tbl_name
WHERE key_part1=constant;
SELECT ... FROM tbl_name
本文源自:http://www.hnbenet.com 转载请注明出处! 更多技术交流请链接:http://www.hnbenet.com/jsjl/
本文由站河南北大青鸟校区整编而成,如需了解更多IT资讯类的文章、新闻、课程和学习技巧、就业案例、招生详情等问题,可以对在线咨询老师进行一对一问答!
推荐资讯
- 河南高中毕业没考上大学去读什么... 2023-08-10
- 北大青鸟云课堂,带你学习带你飞... 2015-04-21
- 让你的手机立即拥有高端机的功能... 2012-10-13
- 郑州北大青鸟电脑培训:vsftpd本地... 2012-10-13
- 嵌入式软件测试的八大方法... 2012-10-13
热点资讯
- 学习SQL数据库有哪些方法?... 2018-09-07
- 河南IT培训:SQLSERVER2000T-SQL的... 2018-09-07
- 使用access数据库有哪些好处呢?... 2018-09-07
- 网站数据库老是被入侵该怎么办?... 2018-09-07
- 半小时让你快速MySQL 入门... 2018-09-07