1.基本原则:优化数据访问

  (1)是否想服务器请求了不需要的数据?提取超过需要的列,多表连接时提取所有列,提取所有列都会消耗不必要的资源,提取你所需要的列就可以了。

  (2)MySQL检查了太多的数据吗?通过查看执行时间,查看检查和返回的行,查看检查的行和访问类型,用expain分析。

2.重构查询的方式

  (1)复杂查询和多个查询。将复杂的查询分解成多个简单的查询。

  (2)缩短查询。也就是分治法,每次只执行一小部分,以减少受影响的行数。

  (3)分解联接。把一个多表联接的查询分解成多个单查询,然后在应用程序端实现联接操作。

3.MySQL客户端/服务器协议

  半双工的,不能同时接收和发送。数据是有服务器端推送给客户端的。查询状态:休眠,查询,锁定,分析和统计,拷贝到磁盘上的临时表,排序结果,发送数据。

4.MySQL查询优化过程

  

  (1)解析------解析器

  (2)预处理----预处理器

  (3)优化------优化器->执行计划

    MySQL能够处理的一些优化包括:

    a.对联接中的表重新排序

    b.将外联接转换成内联接

    c.代数等价法则。

    d.优化count(),min(),max()

    e.计算和减少常量表达式。如果MySQL探测到一个表达式可以被简化成一个常量,那么它就会在优化期做这种转换。比如说,一个用户定义的变量如果没有变化,它就会被转化为一个常量。一些查询语句也会在优化过程被简化为常量。

    f.覆盖索引

    g.子查询优化

    h.早期终结。一旦满足查询或某个步骤的条件,MySQL就会立即停止处理查询,或者该步骤。最明显的例子就是limit

    i.相等传递

    j.比较in()里面的数据。MySQL会对in里面的数据排序,采用二分查找法查找。

    k.表和索引统计

  MySQL的联接执行策略

  优化限制:

    a.MySQL有时把子查询优化得很差,特别是where in。

    b.联合得限制

    c.索引合并优化

    d.相等传递

    e.并行执行

    f.哈希联接

    g.松散索引扫描

    h.MIN()和MAX()

    i.对同一个表进行select和update

(未完待续---------------------------------------------------)

  (4)查询执行

  (5)返回结果到客户端

5.优化特定类型的查询

  (1)优化cout。只使用一个查询统计同一列中不同值的数量,以减少查询的数量。例如:如果使用的是MyISAM存储引擎,因为它的每个表示记录了总行数的,

    select count(*) from  table where id >5;改成select (select count(*) from table)-count(*) from table where id <=5;会要少扫描很多行。

  (2)优化联接。确保on或using使用的列上有索引。确保goup by或order by只引用了一个表中的列。

  (3)优化子查询。尽量使用联接。

  (4)优化group by和distinct。

  使用临时表或文件排序进行分组。使用SQL_SMALL_RESULT强制MySQL选择临时表,SQL_BIG_RESULT强制MySQL选择文件排序。注意临时表示不能建索引的。在一个分组查询中,select子句使用非分组的列通常不是很好,因为结果可能不确定,可以使用SQL_MODE参数中加ONLY_FULL_GROUP_BY,这样服务器会对这样的查询产生一个错误信息。

  使用rollup优化group by。

  (5)优化limit和offset。

  一个简单的提高效率的方法是在覆盖索引上进行偏移,而不是对整行数据进行偏移。如下语句:

  select film_id,description from sakila.film order by title limit 50,5;

  改写成这样:

  select film.film_id.film.decription from salila.film inner join (select film_id from sakila.film order by title limit 50,5) as lim using(film_id);

  另一种方法是把limit转换成位置性查询,让服务器以索引范围扫描的方式来执行。

  (6)优化SQL_CALC_FOUND_ROWS。

  一种可以通过提取并缓存大量数据来优化,也可以通覆盖索引来优化。

  (7)优化联合。使用union all。

参考:《高性能MySQL》

mysql 查询 优化的更多相关文章

  1. Mysql - 性能优化之子查询

    记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...

  2. mysql查询性能优化

    mysql查询过程: 客户端发送查询请求. 服务器检查查询缓存,如果命中缓存,则返回结果,否则,继续执行. 服务器进行sql解析,预处理,再由优化器生成执行计划. Mysql调用存储引擎API执行优化 ...

  3. 30多条mysql数据库优化方法,千万级数据库记录查询轻松解决(转载)

    1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...

  4. mysql性能优化-慢查询分析、优化索引和配置

    一.优化概述 二.查询与索引优化分析 1性能瓶颈定位 Show命令 慢查询日志 explain分析查询 profiling分析查询 2索引及查询优化 三.配置优化 1)      max_connec ...

  5. MySQL SQL优化之in与range查询【转】

    本文来自:http://myrock.github.io/ 首先我们来说下in()这种方式的查询.在<高性能MySQL>里面提及用in这种方式可以有效的替代一定的range查询,提升查询效 ...

  6. Limit参数优化MySQL查询的方法

    在做一些查询时,总希望能避免数据库引擎做全表扫描,因为全表扫描时间长,而且其中大部分扫描对客户端而言是没有意义的.那么,在mysql中有那些方式是可以避免全表扫面?除了通过使用索引列或分区等方式来进行 ...

  7. MySQL查询语句执行过程及性能优化(JOIN/ORDER BY)-图

    http://blog.csdn.net/iefreer/article/details/12622097 MySQL查询语句执行过程及性能优化-查询过程及优化方法(JOIN/ORDER BY) 标签 ...

  8. MySQL查询性能优化(精)

    MySQL查询性能优化 MySQL查询性能的优化涉及多个方面,其中包括库表结构.建立合理的索引.设计合理的查询.库表结构包括如何设计表之间的关联.表字段的数据类型等.这需要依据具体的场景进行设计.如下 ...

  9. MySQL查询不使用索引汇总 + 如何优化sql语句

    不使用索引原文 : http://itlab.idcquan.com/linux/MYSQL/918330.html MySQL查询不使用索引汇总 众所周知,增加索引是提高查询速度的有效途径,但是很多 ...

随机推荐

  1. shell 几中专用修饰符 :- :+ := ${variable:offset:length}

    1.${variable:-word} ${variable:-word} 如果variable已经被设置了,且不为空,则代入它的值,否则代入word; $ fruit=peach $ echo ${ ...

  2. 【05】Number图解

    [05]Number图解  

  3. 工作记录:maven远程下载的问题

    最近使用maven的时候遇到一个问题,每次构建都从https://repository.apache.org/snapshots仓库下载一些maven-metadata.xml,但是公司的环境又连不上 ...

  4. Dialog共通写法(一个button)

    一个button的: package jp.co.hyakujushibank.view import android.app.Dialogimport android.content.Context ...

  5. 【Luogu】P1352没有上司的舞会(树形DP)

    题目链接 设f[i][0]表示第i个人不去舞会时子树的最大欢乐度,f[i][1]表示第i个人去舞会时子树的最大欢乐度. 则有状态转移方程:f[i][0]+=∑max(f[to][0],f[to][1] ...

  6. BZOJ 2780 [Spoj]8093 Sevenk Love Oimaster ——广义后缀自动机

    给定n个串m个询问,问每个串在n个串多少个串中出现了. 构建广义后缀自动机,(就是把所有字符串的后缀自动机合并起来)其实只需要add的时候注意一下就可以了. 然后对于每一个串,跑一边匹配,到达了now ...

  7. [luoguP2331] [SCOI2005]最大子矩阵(DP)

    传送门 orz不会做... 一个好理解的做法(n^3*k): 分n=1和n=2两种情况考虑. n=1时,预处理出前缀和sum[]. 设f[i][j]为到达第i格,已经放了j个子矩阵的最大和, 那么每次 ...

  8. IBM内存三技术:Chipkill、MPX、MM

    转自:解析IBM内存三技术:Chipkill.MPX.MM 内存作为服务器中的又一个重要的组成部分,对于企业的应用起着十分重要的作用.如今,企业用户对于服务器的要求逐渐提升,使得在提高内存密度.增大内 ...

  9. http 400报错

    http 400报错---springmvc相关: 1.使用了json入参,传递给了对象,如果对象里的属性,如这里的Bonus是int类型,你传入了非int类型,这里就会报400 2.使用了@Requ ...

  10. css3鼠标点击穿透--摘抄

    有些时候网页中用到了一些绝对定位的Div,因为需要事先这个Div是隐藏的,但是它所在的位置会遮挡住鼠标点击事件.这个时候可以用CCS3中的pointer-events属性来解决.   //穿透该层 p ...