当前位置: 首页 > wzjs >正文

杭州精品课程网站建设百度信息流推广教程

杭州精品课程网站建设,百度信息流推广教程,wordpress前端工具箱,下载浏览器并安装前言: 我们常说的SQL优化,简单来说就是索引优化,通过合理创建索引,调整SQL语法等,来提升查询效率,想要进行SQL优化,就必须知道索引的原理,而且能够看懂SQL的执行计划。 MySQL–索引…

前言:

我们常说的SQL优化,简单来说就是索引优化,通过合理创建索引,调整SQL语法等,来提升查询效率,想要进行SQL优化,就必须知道索引的原理,而且能够看懂SQL的执行计划。

MySQL–索引底层数据结构详解
MySQL–索引类型详解
MySQL–explain执行计划详解

准备数据:

本篇数据都基于上一篇,传送门如下:
MySQL–索引优化实战篇(1)
MySQL–索引优化实战篇(2)
MySQL–索引优化实战篇(3)

案例一 or 查询:

explain select * from user where user_name='张三' or age=28 and address='广东';

执行计划:

在这里插入图片描述

分析执行计划:

  • key为空,很明显,没有使用到联合索引 index_name_age_address。

原因:SQL语法使用了 or ,导致无法使用索引了。

那怎么才能命中索引呢?同样是使用覆盖索引,如下:

explain select user_name,age,address from user where user_name='张三' or age=28 and address='广东';

执行计划:

在这里插入图片描述
分析执行计划:

  • 同样的查询条件,只是这次指定返回联合索引中的字段,这次就走了索引。

结论:跟猜想一致,or 查询使用覆盖索引后可以命中索引,返回字段不是很多的时候,我们可以尽量去设计走覆盖索引。

案例二 in 和 not in 查询:

explain select *  from user where user_name='张三' and age in (23,25,28) and address='广东';

执行计划:

在这里插入图片描述
分析执行计划:

  • 使用了 index_name_age_address 索引,没有问题。
  • key_len 1006,根据前面几篇分析可知联合索引 index_name_age_address 的三个字段都命中了索引,复合最左前缀法则,没有问题。

再看 not in:

explain select *  from user where user_name='张三' and age not in (23,25,28) and address='广东';

执行计划:

在这里插入图片描述

分析执行计划:

  • 使用了 index_name_age_address 索引,没有问题。
  • key_len 204,根据前面几篇分析可知只命中了联合索引 index_name_age_address 的user_name 和 age 字段,address 字段并没有命中索引。

结论:in 和 not in 都可以走索引,并非很多资料所说 in查询走索引,not in 查询不走索引,但是还是可以看出来,in 查询可以命中跟多的索引,对应的效率也会高一些,具体是 in 查询还是用 not in 查询要根据实际情况而定,总之就是需要合理设计索引,多看SQL执行计划。

索引优化小技巧:

  • 多看执行计划,只有看了执行计划且看懂了,才能进行SQL优化。
  • 多使用联合索引,少使用单列索引。
  • 合理使用覆盖索引,可以解决很多不能命中索引的情况。
  • 按需返回结果,尽量不要使用 select * from table。
  • 谨慎使用 or、!=、not in、is nul、is not null 等。
  • 多尝试不同的SQL写法,比如有时候使用 exists 代替 in 查询。
  • 尽量使用后缀模糊查询,谨慎使用前缀模糊查询。
  • 对于group by 引起的filesort,可以尝试使用order by null来禁止分组后排序。
  • 实践实践验真理的唯一标准。

如有不正确的地方请各位指出纠正。

http://www.dtcms.com/wzjs/70694.html

相关文章:

  • app定制开发谈判技巧山东网络推广优化排名
  • 官方网站弹幕怎么做友情链接的网站有哪些
  • 做旅游网站的公司网站seo方案撰写
  • wordpress向登录页面跳转百度seo教程视频
  • 公安网站服务平台在线视频观看免费视频22
  • 微商城网站建设平台如何做网站推广广告
  • 威海高新园区建设运营有限公司网站网络营销的优缺点
  • 自己做导航网站google推广妙招
  • 推广型网站建设模板网站开发是做什么的
  • 网站空间期限查询天津快速关键词排名
  • 庆阳网站设计费用国外网站设计
  • 怎样提交网站百度收录金城武重庆森林经典台词
  • 网站模板破解版sem优化策略
  • 九江建网站多少钱社交网络的推广方法有哪些
  • 虹桥做网站公司注册域名要钱吗
  • 无锡做网站优化多少钱软文发稿平台
  • 杭州做网站的公司哪些比较好百家号排名
  • 苏州网上注册公司流程最好的网站优化公司
  • 做网站如何挂支付系统百度搜索引擎优化详解
  • 门户网站模板源码百度seo排名培训
  • 网站建设需要哪些的ps如何创建自己的个人网站
  • 徐州网站建设大前端怎么知道网站有没有被收录
  • 如何做好品牌网站建设方案seo 推广怎么做
  • 京东网站建设的经费预算如何搭建公司网站
  • 西宁的网站建设公司618网络营销策划方案
  • 大连网站建设大全h5网站制作平台
  • 阜阳哪里做网站网站流量监控
  • 北京网站建设最便宜的公司产品营销策划方案3000字
  • 给公司做网站风险手机百度
  • 宝塔做两个网站6阿森纳英超积分