Mysql explain-type使用详解

Mysql explain-type使用详解下面是测试用例,楼主的测试使用的MySQL版本是5.6.27-log。show createtableuser_man;CREATETABLE`user_man`( `manid`bigint(20)NOTNULLAUTO_INCREMENT, `manname`varchar(32)DEFAULTNULL, `manage`int(6)DEFAULTNULL…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

下面是测试用例,楼主的测试使用的MySQL版本是5.6.27-log。

show  create table user_man;

CREATE TABLE `user_man` (

  `manid` bigint(20) NOT NULL AUTO_INCREMENT,

  `manname` varchar(32) DEFAULT NULL,

  `manage` int(6) DEFAULT NULL,

  `upd_time` timestamp NOT NULL DEFAULT ‘2000-01-01 00:00:00’ ON UPDATE CURRENT_TIMESTAMP,

  `blacklist` bigint(20) DEFAULT ‘-1’ COMMENT ‘-1,1’,

  PRIMARY KEY (`manid`),

  KEY `IDX_MN` (`manname`) USING BTREE,

  KEY `IDX_MID` (`manid`) USING BTREE

) ENGINE=InnoDB AUTO_INCREMENT=23 DEFAULT CHARSET=utf8;

show  create table user_woman;

CREATE TABLE `user_woman` (

  `womanid` int(11) NOT NULL AUTO_INCREMENT,

  `womanname` varchar(20) DEFAULT NULL,

  `womanage` int(6) DEFAULT NULL,

  PRIMARY KEY (`womanid`)

) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;

#执行计划中type定义说明:

#(1)执行计划type为ALL:遍历全表来查找

explain  SELECT * from user_man ;

explain select * from user_man where manage in (9,10);#非索引范围查找也是走全表

#(2)执行计划type为index:只遍历索引树

explain SELECT manid from user_man;

#(3)执行计划type为range:索引扫描范围

explain select *from user_man where manid  < 10;

explain select * from user_man where manid in (8,10,9) order by manage;

#(4)执行计划type为ref:非唯一性扫描索引

explain select *from user_man where manname = ‘zzk’;

#(5) 执行计划type为eq_ref:唯一性索引扫描

explain select * from user_man ,user_woman where user_man.manid = user_woman.womanid;

explain select * from user_man where manid in (select womanid from user_woman);

#(6)执行计划type为const、system:当MySQL对查询某部分进行优化,并转换为一个常量时,使用这些类型访问。如将主键置于where列表中,MySQL就能将该查询转换为一个常量

explain select *from user_man where manid = 8;

explain select * from (select * from user_man where manid=8) dd;

#(7)NULL:MySQL在优化过程中分解语句,执行时甚至不用访问表或索引

explain select * from user_man where manid = (select min(womanid) from user_woman)

#查询中若使用了覆盖索引,则该索引仅出现在key列表中(为manid、manname建立了索引,单独查这两个字段);

explain select manid ,manname from user_man where manname = ‘zzzz’ and manage = 43;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/180940.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Pandas merge函数「建议收藏」

    Pandas merge函数「建议收藏」[toc]函数原型pd.merge(left,right,how=’inner’,on=None,left_on=None,right_on=None,left_index=False,right_index=False,sort=True,suffixes=(‘_x’,’_y’),copy=True,indicator=False,validate=None)参数left:拼接的左侧DataFrame对象r.

  • Delphi2007 下安装ActiveX控件[通俗易懂]

    Delphi2007 下安装ActiveX控件[通俗易懂]此英文文章来自codegear官方网站,但是是讲在BDS2006 下如何安装,我在delphi2007下用此方法,一样通过,原文如下 Description:HowtoimportanActiveXcontrolinBDS2006?Answer/Solution:Herestheprocedureforimportingandinstalling

  • Jquery Ajax 跨域调用asmx类型 WebService范例

    Jquery Ajax 跨域调用asmx类型 WebService范例Ajax在Web2.0时代起着非常重要的作用,然而有时因为同源策略(SOP)(俗称:跨域问题(crossdomain))它的作用会受到限制。在本文中,将学习如何克服合作限制。本文以asmx方式搭建webservice作为测试用后端,给出完整的前后端调用解决方案、范例代码。

  • CentOS 7 yum 安装与配置 JDK

    CentOS 7 yum 安装与配置 JDKCentOS7yum安装JDK1、检查是否已安装JDK及卸载以下命令二选一,中括号选一即可yumlistinstalled|grep[java][jdk]rpm-qa|grep[java][jdk][gcj]执行命令出现如上图所示,需要卸载,反之即不用卸载JAVA环境yum-yremovejava-1.6.0-openjdk*…

  • springboot的自动配置原理/步骤

    springboot的自动配置原理/步骤1、SpringBoot启动的时候加载主配置类(@SpringBootApplication),开启了自动配置功能@EnableAutoConfiguration。 2、@EnableAutoConfiguration作用:     利用AutoConfigurationImportSelector给容器中导入一些组件;可以查看selectImports()方法的内容; …

  • jmeter-实现跨线程组之间传递参数

    jmeter-实现跨线程组之间传递参数

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号