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

石家庄网站建设seo优化营销网站建设对企业带来什么作用

石家庄网站建设seo优化营销,网站建设对企业带来什么作用,实体企业做网站好么,沈阳做网站的公司内容摘要#xff1a;开启慢查询日志捕获慢SQL使用explain分析慢SQL使用show profile查询SQL执行细节常见的SQL语句优化一、开启慢查询日志捕获慢SQL① 查询mysql是否开启慢日志捕获#xff1a;SHOW VARIABLES LIKE %slow_query_log%;如果还没开启的话#xff0c;开启#x…内容摘要开启慢查询日志捕获慢SQL使用explain分析慢SQL使用show profile查询SQL执行细节常见的SQL语句优化一、开启慢查询日志捕获慢SQL① 查询mysql是否开启慢日志捕获SHOW VARIABLES LIKE %slow_query_log%;如果还没开启的话开启SET GLOBAL slow_query_log1;②  查看慢查询的时间阙值SHOW GLOBAL VARIABLES LIKE %long_query_time%;可以根据实际情况去调整时间SET GLOBAL long_query_time2;③ 查询多少SQL超过了慢查询时间的阙值 SHOW GLOBAL STATUS LIKE %Slow_queries%;④ 使用MySQL提供的日志分析工具mysqldumpslow获取差慢SQL举例--获取慢日志中最多的10个SQL./mysqldumpslow -s r -t 10 /PATH/TO/慢日志文件--获取按照时间排序的前10条里面含有左连接的查询语句mysqldumpslow -s t -t 10 -g left join 慢日志文件更多用法可以使用./mysqldumpslow --help 查看二、使用explain分析慢SQL举例EXPLAIN SELECT a.username FROM tb_admin a LEFT JOIN tb_group p ON a.groupId  p.id WHERE a.username xiaophai LIMIT 11、idSELECT查询的序列号包含一组数字表示查询中执行SELECT语句或操作表的顺序包含三种情况① id相同执行顺序由上至下② id不同如果是子查询id序号会递增id值越大优先级越高越先被执行③ 既有相同的又有不同的。id如果相同认为是一组执行顺序由上至下 在所有组中id值越大优先级越高越先执 行。2、select_typeSIMPLE:   简单SELECT查询查询中不包含子查询或者UNIONPRIMARY: 查询中包含任何复杂的子部分最外层的查询SUBQUERY: SELECT或WHERE中包含的子查询部分DERIVED: 在FROM中包含的子查询被标记为DERIVER(衍生) MySQL会递归执行这些子查询把结果放到临时表中UNION: 若第二个SELECT出现UNION则被标记为UNION, 若UNION包含在FROM子句的子查询中外层子查询将被标记为DERIVEDUNION RESULT: 从UNION表获取结果的SELECT3、table显示这一行数据是关于哪张表的4、typetype显示的是访问类型是较为重要的一个指标结果值从最好到最坏依次是systemconsteq_refreffulltextref_or_nullindex_mergeunique_subqueryindex_subqueryrangeindexALL一般来说得保证查询至少达到range级别最好能达到ref。system表只有一行记录(等于系统表)这是const类型的特例平时不会出现const如果通过索引依次就找到了const用于比较主键索引或者unique索引。 因为只能匹配一行数据所以很快。如果将主键置于where列表中MySQL就能将该查询转换为一个常量eq_ref唯一性索引扫描对于每个索引键表中只有一条记录与之匹配。常见于主键或唯一索引扫描ref非唯一性索引扫描返回匹配某个单独值的所有行。本质上也是一种索引访问它返回所有匹配 某个单独值的行然而它可能会找到多个符合条件的行所以它应该属于查找和扫描的混合体range只检索给定范围的行使用一个索引来选择行。key列显示使用了哪个索引一般就是在你的where语句中出现between、、in等的查询这种范围扫描索引比全表扫描要好因为只需要开始于缩印的某一点而结束于另一点不用扫描全部索引indexFull Index Scan index与ALL的区别为index类型只遍历索引树这通常比ALL快因为索引文件通常比数据文件小。 (也就是说虽然ALL和index都是读全表 但index是从索引中读取的而ALL是从硬盘读取的)allFull Table Scan遍历全表获得匹配的行5、possible_keys显示可能应用在这张表中的索引一个或多个。 查询涉及到的字段上若存在索引则该索引将被列出但不一定被查询实际使用6、key实际使用的索引。如果为NULL则没有使用索引。查询中若出现了覆盖索引则该索引仅出现在key列表中。7、key_len表示索引中使用的字节数可通过该列计算查询中使用的索引的长度。在不损失精度的情况下长度越短越好。key_len显示的值为索引字段的最大可能长度并非实际使用长度即key_len是根据表定义计算而得不是通过表内检索出的。8、ref显示索引的哪一列被使用了哪些列或常量被用于查找索引列上的值。9、rows根据表统计信息及索引选用情况大致估算出找到所需记录多需要读取的行数。10、Extra包含不适合在其他列中显示但十分重要的额外信息① Using filesort 说明MySQL会对数据使用一个外部的索引排序而不是按照表内的索引顺序进行读取。MySQL中无法利用索引完成的排序操作称为“文件排序”② Using temporary 使用了临时表保存中间结果MySQL在对查询结果排序时使用临时表。常见于排序order by和分组查询group by③ Using index 表示相应的SELECT操作中使用了覆盖索引(Covering Index)避免访问了表的数据行效率不错。 如果同时出现using where表明索引被用来执行索引键值的查找 如果没有同时出现using where表明索引用来读取数据而非执行查找动作 覆盖索引(Covering Index) 理解方式1SELECT的数据列只需要从索引中就能读取到不需要读取数据行MySQL可以利用索引返回SELECT列表中 的字段而不必根据索引再次读取数据文件换句话说查询列要被所建的索引覆盖 理解方式2索引是高效找到行的一个方法但是一般数据库也能使用索引找到一个列的数据因此他不必读取整个行。 毕竟索引叶子节点存储了他们索引的数据当能通过读取索引就可以得到想要的数据那就不需要读取行了一个索引 包含了(覆盖)满足查询结果的数据就叫做覆盖索引 注意 如果要使用覆盖索引一定要注意SELECT列表中只取出需要的列不可SELECT *, 因为如果所有字段一起做索引会导致索引文件过大查询性能下降④ impossible where WHERE子句的值总是false不能用来获取任何元组⑤ select tables optimized away 在没有GROUP BY子句的情况下基于索引优化MIN/MAX操作或者对于MyISAM存储引擎优化COUNT(*)操作 不必等到执行阶段再进行计算查询执行计划生成的阶段即完成优化⑥ distinct 优化distinct操作在找到第一匹配的元祖后即停止找同样值的操作三、使用show profile查询SQL执行细节Show Profile是MySQL提供可以用来分析当前会话中语句执行的资源消耗情况可以用于SQL的调优测量分析步骤1、查看状态SHOW VARIABLES LIKE profiling;2、开启set profilingon;3、查看结果show profiles;4、诊断SQLshow profile cpu,block io for query 上一步SQL数字号码;ALL显示所有开销信息BLOCK IO显示IO相关开销CONTEXT SWITCHES显示上下文切换相关开销CPU显示CPU相关开销IPC显示发送接收相关开销MEMORY显示内存相关开销PAGE FAULTS显示页面错误相关开销SOURCE显示和Source_functionSource_fileSource_line相关开销SWAPS显示交换次数相关开销注意(遇到这几种情况要优化)converting HEAP to MyISAM 查询结果太大内存不够用往磁盘上搬Creating tmp table创建临时表Copying to tmp table on disk把内存中的临时表复制到磁盘locked四、常见的SQL语句优化1、尽量避免在where字句中使用or来连接条件否则将导致放弃使用索引而进行全表扫描。select id from user where username15623695987 or mobile15623695987;可以这样查询:select id from user where username15623695987 union all  select id from user where mobile15623695987;2、正确使用like查询。%xx%查询会导致索引使用不上select id from user where username like %test%正确使用索引:select id from user where username like test%3、尽量避免在where字句中对字段进行表达式操作错误做法select id from user where score/2 100;应改为select id from user where score 100*2;4、如果确认查询结果数量应尽可能加上limitselect id from user where usernametest limit 1;5、不用要使用隐式转换错误例子select id from user where mobile15689764359 limit 1;select username from user where id15 limit 1;正确做法select id from user where mobile15689764359 limit 1;select username from user where id15 limit 1;6、正确使用复合索引举例user表index  idx_username(username,group_id)能使用索引select id from user where usernametest and group_id1;select id from user where usernametestselect id from user where group_id1 and usernametest不能使用索引select id from user where group_id1;总结 是否使用索引与idx_username(username,group_id)这两个字段的先后顺序有关7、如果使用了join请尽量使用小表join大表8、正确使用exists和in① inselect user.id,user.username from user where user.id in (select order.user_id from order)② existsselect user.id,user.username from user where exists (selectorder.user_id from order where user.id order.user_id)应用场景参考如果子查询得出的结果集记录较少主查询中的表较大且又有索引时应该用in, 反之如果外层的主查询记录较少子查询中的表大又有索引时使用exists
http://www.zqtcl.cn/news/428434/

相关文章:

  • 网站建设国内外研究现状模板ppt设计大赛
  • 专业网站优化方案网站设计过程怎么写
  • 福州定制网站建设网站ip过万
  • wordpress网站评论插件厦门软件网站建设
  • 网站黄金比例wordpress转typecho
  • 重庆有哪些网络公司百度系优化
  • 无锡网站制作方案企业三合一建站公司怎么找
  • 钉钉crm客户管理系统免费seo网站推荐一下软件
  • wordpress公司网站模版怎么显示wordpress里元素的源代码
  • 泉州网站制作运营商专业wordpress评论软件
  • 网站开发是什么意思啊有没有帮人做简历的网站
  • 企业网站模板包含什么维度 网站建设
  • 个人备案做运营网站宁波建网站模板
  • 做网站需要懂什么软件合肥网站制作套餐
  • 中国建设银行官方网站纪念钞预约网上买手表哪个网站可以买到正品
  • 哪个网站做兼职可以赚钱浙江嘉兴最新事件
  • 苍南网站建设深圳百度关键字优化
  • 网站建设流程及规范是做网站设计好还是杂志美编好
  • 网站模板 登陆南昌做网站开发的公司有哪些
  • 移动网站建设是什么商丘哪里教做网站的
  • 网站建设排名的公司江东seo做关键词优化
  • 学习网站开发培训网站内链是什么
  • 中文 域名的网站用wordpress做的网站有哪些
  • 网站建设中需要注意的问题唐山自助建站模板
  • 网站建设捌金手指下拉一重庆 网站定制
  • 网站建设需求调研方法自己做网站要多少钱
  • 北流网站建设公众号开发 表格
  • 做教育类网站一般流程苏宁易购网站风格
  • 兼职网站推广如何做如何用ps做网站
  • 济南外贸网站建设软件公司网站