18SQL优化查询的优化.docVIP

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
18SQL优化查询的优化

优化SQL语句的一般步骤 通过show status 命令了解各种sql的执行频率 通过explain分析低效的SQL的执行计划 Explain的详细用法和explain的列解释在pdf文件mysql_explain中有详细说明,请常看。 确定问题并采取相应的措施 一般为添加索引给查询type为all或者extra为fliesort的表。 索引问题 查看某个表中的索引:show index form table; 1.使用索引 a.Mysql中使用索引,对于多列索引,只有使用最左边的列才能使用索引。 b.对于like查询,后面如果是常量并且%不在第一个字符才能使用索引。另外如果like后面跟的是一个列的名字,也不会使用索引。 c.如果对大文本进行搜索,必须使用全文索引。 d.如果列明是索引,则使用查询...where name is null也是使用了索引。 2.存在索引不使用索引 A.如果mysql估计使用索引比全表索引慢,则不会。如列key均分布在1~100之间,则下列查询使用索引就不好. Select * from table where key 10 and key 80 ; B.如果使用Memory/heap表并且where 条件中不使用 = 进行判断,则不会使用索引,heap表只有在 = 条件下才能使用索引。 C.用or分割开的条件,如果or前的条件中的列有索引而后面的列没有索引,则涉及的索引都不会使用。 D.组合索引使用的不是最左边的列 F.如果like是以%开始的 E.如果列类型是string类型,那么一定要把where语句中的字符常量用引号引起来。如:explain select * from table where name = 247 \G ; 如果不加引号,因为name的索引为string而常量为int,所以不会使用索引。 查看索引的使用情况 如果索引正在工作,Handler_read_key的值将很高。如果这个值不高,代表增加索引的性能改善不高。 Handle_read_rnd_next的值高意味着查询效率低,并且应该建立索引补救。这个值的含义是在数据文件中读下一行的请求数。 如:show status like Handle_read% ;

文档评论(0)

2017ll + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档