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;

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mac phpstrom 激活码【2022最新】「建议收藏」

    (mac phpstrom 激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html4KDDGND3CI-eyJsa…

    2022年4月1日
    107
  • django使用celery_apache django

    django使用celery_apache django前言环境celery==5.0.2在安装完celery后,运行celery会报以下错误ModuleNotFoundError:Nomodulenamed'click._bashc

    2022年7月31日
    8
  • 简单的批处理命令_bat批处理执行cmd命令

    简单的批处理命令_bat批处理执行cmd命令批处理命令简单教程转载来源:https://blog.csdn.net/Joker_N/article/details/89838719文章目录批处理命令简单教程一、常用命令简介1、echo命令2、rem命令3、pause命令4、call命令5、start命令6、goto命令7、set命令二、常用符号简介1、回显屏蔽@2、重定向1>;与>>3、重定向2<4、管道符号|5、转义符^6、逻辑命令符三、命令释义1、文件夹管理2、文件管理3、网络命令4、系统管理四

    2022年8月22日
    6
  • 2.5.1大礼包

    2.5.1大礼包查找:全局搜索 prefs:root=或者 openURL:不要有“prefs:root=xxxx”这个可能出在自己项目中,特别是接手老项目,另一种可能是第三方sdk里出现的特别是调用相册相机调用wifi这类的第三方框架或SDK。如果第三方出现重新下载最新的包或者换第三方,联系第三方sdk开发者修改。修改一般只弹框提示不做跳转或者用苹果提供的方法。不要出现:@"pre…

    2022年7月16日
    15
  • Android点击button弹出ProgressDialog,响应结束后ProgressDialog消失

    Android点击button弹出ProgressDialog,响应结束后ProgressDialog消失ProgressDialog与Handler结合使用,事件响应前弹出dialog,事件响应结束后dialog自动消失。

    2022年7月14日
    20
  • Oracle sql语句修改表名

    Oracle sql语句修改表名方法1:在原表上修改表名ALTERTABLE [原表名称]  RENAME TO [新表名称];方法2:建新表xinTable,将原表oldTable的数据导进去;createtablexintableasselect*fromoldTable;//在原表的基础上建立新表droptableoldTable;//删除原表…

    2022年5月17日
    49

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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