explain extended 获取mysql优化后的sql

explain extended 
SELECT
 jlbh,
 kkbh,
 hphm,
 jgsj,
 clsd
FROM
 sjkk_gcjl s
WHERE
 1 = 1
AND hphm LIKE '%77'
AND jgsj >= '2015-11-10 19:59:59'
AND jgsj <= '2015-11-10 23:59:59'
AND hpys = '2'
ORDER BY
 jgsj DESC,
 jlbh DESC
LIMIT 100;

+----+-------------+-------+------+-------------------------+---------+---------+-------+---------+----------+--------------------------+
| id | select_type | table | type | possible_keys           | key     | key_len | ref   | rows    | filtered | Extra                    |
+----+-------------+-------+------+-------------------------+---------+---------+-------+---------+----------+--------------------------+
|  1 | SIMPLE      | s     | ref  | index04,index10,index14 | index10 | 5       | const | 2394655 |   100.00 | Using where; Using index |
+----+-------------+-------+------+-------------------------+---------+---------+-------+---------+----------+--------------------------+

show warnings;

SELECT
 `pvd_50yi`.`s`.`jlbh` AS `jlbh`,
 `pvd_50yi`.`s`.`kkbh` AS `kkbh`,
 `pvd_50yi`.`s`.`hphm` AS `hphm`,
 `pvd_50yi`.`s`.`jgsj` AS `jgsj`,
 `pvd_50yi`.`s`.`clsd` AS `clsd`
FROM
 `pvd_50yi`.`sjkk_gcjl` `s`
WHERE
 (
  (
   `pvd_50yi`.`s`.`hphm` LIKE '%77'
  )
  AND (
   `pvd_50yi`.`s`.`jgsj` >= '2015-11-10 19:59:59'
  )
  AND (
   `pvd_50yi`.`s`.`jgsj` <= '2015-11-10 23:59:59'
  )
  AND (`pvd_50yi`.`s`.`hpys` = '2')
 )
ORDER BY
 `pvd_50yi`.`s`.`jgsj` DESC,
 `pvd_50yi`.`s`.`jlbh` DESC
LIMIT 100;


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQLEXPLAIN语句用于分析和优化查询语句的执行计划。通过执行EXPLAIN语句,你可以了解MySQL是如何处理你的查询,包括表的访问顺序、使用的索引、连接方式等。 下面是使用EXPLAIN语句来优化SQL查询的步骤: 1. 确定要优化的查询语句。可以使用SELECT语句来查询数据,然后在该语句前加上EXPLAIN关键字。例如:EXPLAIN SELECT * FROM table_name WHERE condition; 2. 执行EXPLAIN语句,并查看结果。执行EXPLAIN后,MySQL会返回一张表格,其中包含了查询的执行计划信息。这些信息可以帮助你分析查询的性能瓶颈。 3. 分析执行计划信息。在执行计划信息表格中,你可以关注以下几个重要的列: - id: 查询的唯一标识符。多表查询时,每个表都有一个唯一标识符。 - select_type: 查询类型。包括简单查询、联接查询、子查询等。 - table: 查询涉及的表名。 - type: 表示MySQL访问表的方式,常见的有ALL、index、range、ref等。 - possible_keys: 表示可能使用的索引。 - key: 实际使用的索引。 - rows: 估计扫描的行数。 - Extra: 额外的信息,如是否使用了临时表、是否使用了文件排序等。 4. 根据执行计划信息来进行优化。根据查询的复杂性和性能要求,你可以采取以下一些优化措施: - 确保表中的列上有适当的索引。 - 使用JOIN语句时,确保连接条件上有索引。 - 避免在查询中使用通配符(如SELECT *)。 - 尽量减少子查询的使用。 - 优化WHERE条件,尽量避免使用OR、NOT等复杂的逻辑判断。 - 使用合适的数据类型,避免不必要的数据类型转换。 通过不断地执行EXPLAIN语句,分析执行计划信息,并针对性地进行优化,你可以提高查询的性能并减少数据库的负载。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值