前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2020-12-26:mysql中,表person有字段id、name、age、sex

2020-12-26:mysql中,表person有字段id、name、age、sex

原创
作者头像
福大大架构师每日一题
修改2020-12-28 11:44:51
7330
修改2020-12-28 11:44:51
举报

2020-12-26:mysql中,表person有字段id、name、age、sex,id是主键,name是普通索引,age和sex没有索引。select * from person where id=1 and name='james' and age=1 and sex=0。请问这条语句有几次回表?

福哥答案2020-12-26:

答案是没有回表。

一般题目是判断有没有回表,而这道题是要说出有几次回表。

刚开始以为会用到回表。后来想了想,没有回表。id是等值查询,顶多命中1条数据。然后再对这1条数据做name过滤,就这么1条数据,没必要回表查询,连我都能想到,mysql的作者更能想到,mysql没那么傻。

有什么不对的地方,请直接留言评论。

1.创建表和插入数据:


-- Table structure for person 表结构


DROP TABLE IF EXISTS person;

CREATE TABLE person (

id int(11) NOT NULL,

name varchar(255) NOT NULL,

age int(11) NOT NULL,

sex tinyint(4) NOT NULL,

PRIMARY KEY (id),

KEY name (name)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;


-- Records of person,表中记录


INSERT INTO person VALUES ('1', 'james', '11', '1');

INSERT INTO person VALUES ('2', 'haha', '12', '0');

INSERT INTO person VALUES ('3', '福大大', '13', '2');

2.查看执行计划:

EXPLAIN SELECT * FROM person WHERE id=3;

EXPLAIN SELECT * FROM person WHERE id=3 AND name='福大大';

EXPLAIN SELECT * FROM person WHERE id=3 AND name='福大大' AND age=13;

EXPLAIN SELECT * FROM person WHERE id=3 AND name='福大大' AND age=13 AND sex=2;

在这里插入图片描述
在这里插入图片描述

评论

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档