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

做特殊任务的网站医院门户网站建设方案

做特殊任务的网站,医院门户网站建设方案,包装材料网站建设,手表网站哪个最好知乎一、慢查询日志 描述#xff1a;通过慢查询日志等定位那些执行效率较低的SQL语句 查看 # 慢查询是否开启 show variables like slow_query_log%; # 慢查询超时时间 show variables like long_query_time%;执行SQL 开启慢查询日志 set global slow_query_log ON;设置慢查…一、慢查询日志 描述通过慢查询日志等定位那些执行效率较低的SQL语句 查看 # 慢查询是否开启 show variables like slow_query_log%; # 慢查询超时时间 show variables like long_query_time%;执行SQL 开启慢查询日志 set global slow_query_log ON;设置慢查询超时时间秒为单位 set global long_query_time 2;修改配置文件 slow_query_log ON long_query_time 4 slow_query_log_file D:/xxxx查看日志 mysqldumpslow -s t -t 10 -g select D:/xx二、EXPLAIN分析SQL执行计划 explain select * from ......列描述id在一个大的查询语句中每个SELECT关键字都对应一个唯一的Idselect_typeSELECT关键字对应的那个查询的类型table表名partitions匹配的分区信息type针对单表访问方法possible_keys可能用到的索引key实际上使用的索引key_len实际使用到的索引长度ref当使用索引列等值查询时与索引列进行等值匹配的对象信息rows预估的需要读取的记录条数filtered某个表经过搜索条件过滤后剩余记录条数的百分比Extra—些额外的信息 2.1 详细说明 2.1.1 id id列的编号是 select 的序列号有几个 select 就有几个id并且id的顺序是按 select 出现的顺序增长的。 2.1.2 select_type select_type 表示对应行是简单还是复杂的查询。 simple简单查询。查询不包含子查询和unionprimary复杂查询中最外层的 selectsubquery 包含在 select 或where列表子查询中不在 from 子句中derived包含在 from 子句中的子查询。MySQL会将结果存放在一个临时表中也称为派生表union在 union 中的第二个和随后的 selectunion result从 union 临时表检索结果的 select 2.1.3. table 这一列表示 explain 的一行正在访问哪个表。 2.1.4. type 这一列表示关联类型或访问类型即Mysql决定如何查找表中的行查找数据行记录的大概范围。依次从最优到最差分别为system const - eq_ref ref range index ALL SQL语句最好能保证查询达到range级别最好达到ref NULLmysql 能够在优化阶段分解查询语句在执行阶段用不着再访问表或索引。例在索引列中选取最小值可以单独查询索引来完成。 EXPLAIN SELECT min(CODE) FROM villageconst,systemmysql能对查询的某部分进行优化并将其转化成一个常量可以看show warnings的结果。用于primary key 或 unique key的所有列与常量比较时所有表最多有一个匹配行读取1次速度比较快。system是const的特列表里只有一条元组匹配时为system。 EXPLAIN select * from (select * FROM village where CODE 110101001001) tmp;eq_refprimary key或unique key索引的所有部分被连接使用最多只会返回一条符合条件的记录。这可能时在const之外最好的联接类型了简单的select查询不会出现这种type。 EXPLAIN SELECT * FROM street inner join village on village.streetCode street.coderef相对eq_ref不使用唯一索引而是使用普通索引或者唯一性索引的部分前缀索引要和某个值相比较可能会找到多个符合条件的行。 EXPLAIN SELECT * FROM village WHERE name 银闸社区居委会range范围扫描通常出现在 in(), between , ,, 等操作中。使用一个索引来检索给定范围的行。 EXPLAIN SELECT * FROM street WHERE cityCode BETWEEN 5108 and 5500index扫描全表索引这通常比ALL快一些。index是从索引中读取的而all是从硬盘中读取。 EXPLAIN SELECT CODE FROM area2 WHERE CODE 1000ALL即全表扫描意味着mysql需要从头到尾去查找所需要的行。通常情况下这需要增加索引来进行优化了。 EXPLAIN SELECT * FROM area2 2.1.5 possible_keys 这一列显示查询可能使用哪些索引来查找。 explain 时可能出现 possible_keys 有列而 key 显示 NULL 的情况这种情况是因为表中数据不多mysql认为索引对此查询帮助不大选择了全表查询。 如果该列是NULL则没有相关的索引。在这种情况下可以通过检查 where 子句看是否可以创造一个适当的索引来提高查询性能然后用 explain 查看效果。 2.1.6. key 这一列显示mysql实际采用哪个索引来优化对该表的访问如果没有使用索引则该列是 NULL。如果想强制mysql使用或忽视possible_keys列中的索引在查询中使用 force index、ignore index。 2.1.7 key_len 这一列显示了mysql在索引里使用的字节数通过这个值可以算出具体使用了索引中的哪些列。 一般情况下key_len值越小越好索引越短既节约空间速度又比较快 2.1.8 ref 这一列显示了在key列记录的索引中表查找值所用到的列或常量常见的有const常量字段名 2.1.9 rows 这一列是mysql估计要读取并检测的行数注意这个不是结果集里的行数 2.1.10 Extra 这一列展示的是额外信息。常见的重要值如下 Using index使用覆盖索引。Using where使用 where 语句来处理结果并且查询的列未被索引覆盖。Using index condition查询的列不完全被索引覆盖需要回表查询。Using temporaryMySQL 需要创建一张临时表来处理查询。出现这种情况一般是要进行优化的首先是想到用索引来优化。Using filesort将用外部排序而不是索引排序需要注意的是不要被这个 Using filesort 名字欺骗了并非出现这个就会使用磁盘排序而是数据较小时从内存排序否则需要在磁盘排序。这种情况下一般也是要考虑使用索引来优化的。Select tables optimized away使用某些聚合函数(比如 max、min)来访问存在索引的某个字段时出现。
http://www.hkea.cn/news/14380495/

相关文章:

  • 电子商务网站建设试题及答案如何给网站做二维码
  • 怎么和网站合作推广海外品牌推广
  • 编写网站策划方案百度网站名片
  • 酒店官方网站的功能建设手机免费建设网站制作
  • 如何在工商局网站做企业年报池州网站建设价格
  • ppt 如何做网站交互式赶集招聘网
  • 网站建设免费软件adspower浏览器
  • 沧州网站艰涩很沧州外贸网站建设
  • 如何建立一个手机网站线上引流的八种推广方式
  • 电话销售网站建设郑州网页设计制作
  • 洛阳网站建设多少钱wordpress importer
  • 网站怎么上传购物网站后台流程图
  • 太康县城乡建设局规划网站window主机用wordpress
  • 外贸型企业网站建设wordpress广告收入
  • 嘉兴网站模板建站做网站都用什么技术
  • 浙江网站开发公司长沙做网络推广公司的
  • 网站建设商业阶段去国外怎么导航地图
  • 做网站需要用到的软件杭州网站建设faxide
  • 装潢设计网站鞍山玉佛苑导游词
  • 河南微网站建设公司惠州 网站建设
  • 地下城做解封任务的网站扁平网站 文案
  • 免费网站推广软件下载东莞百度网站优化
  • 如何用服务器搭建自己的网站所有网站302跳转百度
  • 如何建论坛网站微信商城软件开发
  • 开封网站制作网站上的个人词条怎么做的
  • 公司网站及微信公众号建设意义wordpress评论可看
  • 专业微网站开发公众号开发者密码忘了怎么办
  • 赣州制作网站百度门户网站模板之家
  • 珠海网站建设小小网络品牌推广是什么
  • 免费试用网站空间电话网站域名到期