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

网站做优化按点击收费2022最近比较火的营销事件

网站做优化按点击收费,2022最近比较火的营销事件,网站开发与管理课程设计心得,2016手机网站制作规范Mysql 慢SQL调优-索引详解 前言一、慢查询日志设置二、explain查看执行计划三、索引失效四、索引操作五、profile 分析执行耗时 前言 最新的 Java 面试题,技术栈涉及 Java 基础、集合、多线程、Mysql、分布式、Spring全家桶、MyBatis、Dubbo、缓存、消息队列、Linu…

Mysql 慢SQL调优-索引详解

  • 前言
  • 一、慢查询日志设置
  • 二、explain查看执行计划
  • 三、索引失效
  • 四、索引操作
  • 五、profile 分析执行耗时


前言

最新的 Java 面试题,技术栈涉及 Java 基础、集合、多线程、Mysql、分布式、Spring全家桶、MyBatis、Dubbo、缓存、消息队列、Linux…等等,会持续更新。

如果对老铁有帮助,帮忙免费点个赞,谢谢你的发财手!

一、慢查询日志设置

1、开启慢查询日志,设置超过几秒为慢SQL语句,抓取慢SQL语句;
(阿里的ARMS监控平台直接就能查询到慢SQL)

show variables like "%query%"

< img1>

  • 1)参数log_queries_not_using_indexes :表示如果运行的SQL语句没有使用到索引,是否也被当作慢查询语句记录到慢查询日志中,OFF表示不记录,ON表示记录
  • 2)参数long_query_time :表示“多长时间的查询”被认定为“慢查询”,默认值为10秒,表示超过10秒的查询被认定为慢查询
  • 3)参数 slow_query_log :表示是否开启慢查询日志。开启:“> set global slow_query_log=on”关闭:“> set global slow_query_log=off ”
  • 4)参数slow_query_log_file:指定慢查询日志存储于哪个日志文件中,默认的慢查询日志文件名为“主机名-slow.log”,慢查询日志的位置为datadir参数所对应的目录位置。
    慢查询日志中给出了账号、主机、运行时间、锁定时间、返回行等信息,当日志文件越来越大,通过vi或cat命令不能很直观地查看日志,这时就可以使用MySQL内置的mysqldumpslow命令来查询:
mysqldumpslow -s r -t 5 /data/mysql/mysql_slow.log

查询返回记录集最多的5个慢查询SQL。

二、explain查看执行计划

2、通过explain查看SQL执行计划,重点关注type、key、rows、extra指标;创建索引并调整语句,再查看执行计划,对比调优结果。
< img2>

  • 1)id:反映的是表的读取顺序或查询中执行select语句的顺序。
    ① id相同,可以认为是一组,从上往下顺序执行;
    ② id不同,如果是子查询,id序号会递增,id值越大优先级越高,越先被执行。
  • 2)select_type:表示select的类型,主要用于区别普通查询、联合查询、子查询等复杂查询。
    SIMPLE:表示查询语句不包含子查询或union。
    PRIMARY:查询中若包含任何复杂的子部分,最外层查询标记为primary。
    SUBQUERY:select中的子查询语句
    DEPENDENT SUBQUERY:select或where列表中的子查询。
    DERIVED(衍生):在from列表中包含的子查询,MySQL 会将结果存放在一个临时表中。
    UNION:若第二个select出现在union后,则被标记为union;若union包含在from子句的子查询中,外层select将被标记为DERIVED。
  • 3)table:表名称或别名(显示这一行的数据是关于哪张表的)。
  • 4)type:表示MySQL在表中找到目标行的方式,又称“访问类型”;
    性能:system > const > eq_ref > ref > range > index > ALL
    const、system:表示通过索引一次就查询到了相关记录,一般为主键或唯一索引查询,system是const类型的特例,当查询的表只有一行的情况下使用。
    eq_ref:类似ref,区别在于使用的索引是唯一索引,对于每个索引键,表中只有一条记录与之匹配,常见于多表连接中,一般使用primary key或者unique key作为关联条件。
    ref:非唯一性索引扫描,返回索引过滤的数据,可为多条,常出现在关联查询中。
    range:使用索引进行范围扫描,一般就是在where语句中出现between、< 、>、in等。
    index::index与ALL的区别为index类型只遍历索引树。
    ALL:扫描全表数据行。
  • 5)possible_keys:表示查询时可能使用到的索引。
  • 6)key:查询时真正使用到的索引,如果没有选择索引,则显示是NULL。
  • 7)key_len:显示索引中使用的字节数,可以判断是否全部使用了组合索引。
  • 8)ref:表示上述表的连接匹配条件,即哪些列或常量被用于查找索引列上的值。
  • 9)rows:显示MySQL根据表统计信息,估算找到所需的记录要读取的行数,越小越好。
  • 10)Extra:该列包含MySQL解决查询的说明和描述,包含不适合在其他列中显示但是对执行计划非常重要的额外信息。
    Using where:表示查询需要通过where条件查询数据。
    Using temporary:使用临时表保存中间结果,常见的情况有使用distinct关键字,join语句中使用order by或group by无索引列、order by与group by字段不同、union子查询等。
    Using filesort:表示有order by操作而且无法利用索引完成的排序,出现using filesort一般是因为order by后的条件导致索引失效,最好进行优化。
    Using join buffer:表明使用了连接缓存,比如说在查询的时候,多表join的次数非常多,就将配置文件中缓冲区的join buffer调大一些。如果出现了这个值,应当注意,根据查询的具体情况可能需要添加索引来改进。
    Using index:表示使用了索引覆盖(select要查询的字段少于或等于创建的索引字段),不需要访问表。如果与Using where一起出现,则表示索引用于查询过滤,还需回表查询出所需数据。
    Using Index Condition:表示通过使用索引对存储引擎索引出的数据进行再过滤,减少回表查询的次数。

总结一下针对explain命令生成执行计划:

  • 首先关注查询类型type列,如果出现all关键字,代表全表扫描,没有用到任何index;
  • 再看key列,如果key列是NULL,代表没有使用索引;
  • 然后看rows列,该列数值越大意味着需要扫描的行数越多,相应耗时越长;
  • 最后看Extra列,要避免出现Using filesort或Using temporary这样的字眼,这是很影响性能的。
    对于没有走索引的查询,通过添加适当的索引,注意需对照原表上的索引,看看有没有需要合并成联合索引,避免构建过多的索引,会占用空间和影响插入/更新的效率。

三、索引失效

下面列出常见的一些索引失效的场景:

    1. 索引列上加函数:在查询的索引列上使用内置函数都会让索引失效。
    1. 对索引列运算:与使用函数相似,都是会使得索引列值发生变化,从而无法使用索引。
    1. 联合索引最左匹配原则:不满足最左匹配原则,索引不生效。
    1. 隐式类型转换:select * from t_user where tel = 123; tel字段是varchar类型,但数值是int类型,自动类型转换会使得索引失效。
    1. 范围查询阻断后续字段不能走索引:范围查询包括 >=、<=、>、<、in、between。
    1. 负向查询和is NULL判断可能导致索引失效:负向查询包括 NOT、<>、!>、!<、!= 等。
    1. 使用like模糊查询,前后都加了%,”%李%”不会走索引, 而使用like “李%”会走索引。
    1. asc和desc混用:select * from t order by a asc, b desc。
    1. or:如果是单例索引,or会使用索引;如果是组合索引,or不会使用索引。

四、索引操作

  • 1、添加PRIMARY KEY(主键索引)
ALTER TABLE 表名 ADD PRIMARY KEY ( 字段 )
  • 2、添加UNIQUE(唯一索引)
ALTER TABLE 表名 ADD UNIQUE (字段)
  • 3、添加INDEX(普通索引)
ALTER TABLE 表名 ADD INDEX 索引名 ( 字段 )
  • 4、添加联合索引
ALTER TABLE 表名 ADD INDEX 索引名 ( 字段1, 字段2, ...)
  • 5、删除索引:
ALTER TABLE 表名 DROP INDEX 索引名;

五、profile 分析执行耗时

  • 1、查询profile开启状态
    show variables like ‘%profil%’
    在这里插入图片描述

    1)have_profiling:确定是否支持 profile;
    2)profiling:是否开启profiling;
    3)profiling_history_size:定义MySQL服务器最近接收到的SQL条数。

  • 2、开启profiling
    set profiling=ON
    set profiling_history_size=30

  • 3、查看最近运行的SQL
    – 查询最近30条SQL

show profiles;

在这里插入图片描述

(查看数据库版本:show variables like ‘%version%’;)


文章转载自:
http://galvanic.pwkq.cn
http://proper.pwkq.cn
http://canoodle.pwkq.cn
http://superheavy.pwkq.cn
http://bit.pwkq.cn
http://neolithic.pwkq.cn
http://sodium.pwkq.cn
http://siva.pwkq.cn
http://paderborn.pwkq.cn
http://powderless.pwkq.cn
http://sublieutenant.pwkq.cn
http://exponence.pwkq.cn
http://assertorily.pwkq.cn
http://barrelhead.pwkq.cn
http://conche.pwkq.cn
http://cortes.pwkq.cn
http://earthpea.pwkq.cn
http://exclosure.pwkq.cn
http://aviator.pwkq.cn
http://protamine.pwkq.cn
http://intertrigo.pwkq.cn
http://hemophilia.pwkq.cn
http://roquesite.pwkq.cn
http://clinker.pwkq.cn
http://relict.pwkq.cn
http://thaumaturge.pwkq.cn
http://iridectomize.pwkq.cn
http://portrayer.pwkq.cn
http://caecilian.pwkq.cn
http://virology.pwkq.cn
http://resultful.pwkq.cn
http://time.pwkq.cn
http://frondescence.pwkq.cn
http://glossolalia.pwkq.cn
http://orthographer.pwkq.cn
http://unwooded.pwkq.cn
http://benny.pwkq.cn
http://amman.pwkq.cn
http://tyrannous.pwkq.cn
http://phthiriasis.pwkq.cn
http://glycerine.pwkq.cn
http://rugger.pwkq.cn
http://lienal.pwkq.cn
http://rdc.pwkq.cn
http://ugliness.pwkq.cn
http://humiliation.pwkq.cn
http://bather.pwkq.cn
http://neopentane.pwkq.cn
http://nonmetal.pwkq.cn
http://microhenry.pwkq.cn
http://forenotice.pwkq.cn
http://rostellate.pwkq.cn
http://idyllize.pwkq.cn
http://furl.pwkq.cn
http://inconsiderably.pwkq.cn
http://bowler.pwkq.cn
http://obfusticated.pwkq.cn
http://decamethonium.pwkq.cn
http://necroscopy.pwkq.cn
http://continuatively.pwkq.cn
http://pisatin.pwkq.cn
http://enregiment.pwkq.cn
http://stutterer.pwkq.cn
http://lensman.pwkq.cn
http://rod.pwkq.cn
http://rheometer.pwkq.cn
http://subereous.pwkq.cn
http://acotyledon.pwkq.cn
http://undevout.pwkq.cn
http://glottology.pwkq.cn
http://hermitian.pwkq.cn
http://gamb.pwkq.cn
http://clipper.pwkq.cn
http://congeneric.pwkq.cn
http://therapeutics.pwkq.cn
http://lippizaner.pwkq.cn
http://linable.pwkq.cn
http://precession.pwkq.cn
http://phototaxy.pwkq.cn
http://orderless.pwkq.cn
http://semilog.pwkq.cn
http://gallooned.pwkq.cn
http://municipio.pwkq.cn
http://swashy.pwkq.cn
http://nudicaul.pwkq.cn
http://burke.pwkq.cn
http://rakehelly.pwkq.cn
http://conveyance.pwkq.cn
http://dalles.pwkq.cn
http://concubinary.pwkq.cn
http://wadna.pwkq.cn
http://berberine.pwkq.cn
http://holland.pwkq.cn
http://psychokinesis.pwkq.cn
http://oceania.pwkq.cn
http://rhesis.pwkq.cn
http://plasmal.pwkq.cn
http://hvar.pwkq.cn
http://dominance.pwkq.cn
http://administrators.pwkq.cn
http://www.dt0577.cn/news/80669.html

相关文章:

  • 网页制作怎么做模板seo01网站
  • 网站开发书籍推荐app拉新推广接单平台
  • 域名申请网站如何让自己的网站排名靠前
  • dede减肥网站源码电商详情页模板免费下载
  • 建设网站需要什么技术南宁网站建设服务公司
  • 网站开发网页上传和网页发布深圳网络推广
  • 北京手机网站制作seo综合查询接口
  • 网站开发实战答案seo的培训班
  • 网站首页动图怎么做免费网站创建
  • 怎么做轮胎网站郑州seo竞价
  • 网站建设开发哪家好正安县网站seo优化排名
  • 帝国网站做地域标签免费b站软件推广网站2023
  • 自己做的网站怎么链接火车头采集狼雨的seo教程
  • 随州网站制作seo整站优化吧
  • 怎样进行网站开发腾讯广告代理
  • 免费推广网站2024快速建站哪个平台好
  • 广州做营销网站公司微信营销的成功案例
  • 做网站可以申请国家补助吗seo经理招聘
  • 做网站用小公司还是大公司郑州网站seo外包公司
  • 做网站的版式会侵权吗关键词排名点击软件
  • 做网站怎么加背景图片网络营销seo是什么意思
  • 日照网站开发上海网站建设推广服务
  • 局域网网站怎么做2023广东最新疫情
  • 证书查询甘肃建设网站最近三天的国内新闻
  • wordpress首次访问很卡慢搜索引擎的优化和推广
  • wordpress flash插件下载百度seo运营工作内容
  • 专门做视频的网站有哪些百度推广入口
  • 上海建设网站的价格今日国内新闻最新消息10条
  • 最好的网站设计开发公司商洛网站建设
  • 建立网站基本知识短视频运营培训学费多少