小伙伴们在面试的时候,有一个特别常见的问题,那就是数据库的回表。什么是回表?为什么需要回表? 今天松哥就来和大家聊一聊这个话题。 1....索引结构 要搞明白这个问题,需要大家首先明白 MySQL 中索引存储的数据结构。这个其实很多小伙伴可能也都听说过,B+Tree 嘛! B+Tree 是什么?...对于第二种查询方式而言,一共搜索了两棵 B+Tree,第一次搜索 B+Tree 拿到主键值后再去搜索主键索引的 B+Tree,这个过程就是所谓的回表。...一定会回表吗? 那么不用主键索引就一定需要回表吗? 不一定! 如果查询的列本身就存在于索引中,那么即使使用二级索引,一样也是不需要回表的。...好啦,今天的主题是回表,现在大家明白什么是回表了吧?
: mysql> create table if not exists user1( -> id int, -> name varchar(20) comment '用户名',...-> )character set utf8 collate utf8_general_ci engine MyIsam; Query OK, 0 rows affected (0.00 sec) mysql...> 创建表user2: mysql> create table if not exists user2( -> id int, -> name varchar(20) comment...xingming varchar(60) DEFAULT NULL; 向表中插入数据insert into values mysql> insert into user values (1,'张三...','12345','2010-10-1'); Query OK, 1 row affected (0.00 sec) mysql> insert into user values (2,'李四','
MySQL基本查询 表的增删改查:CRUD Create(创建)包含insert Retrieve(读取)包含select Update(更新) Delete(删除) 一.增加数据Create 主要是...,但冲突数据的值和 update 的值相等 1 row affected: 表中没有冲突数据,数据被插入 2 row affected: 表中有冲突数据,并且数据已经被更新 此外,通过 MySQL...比如,可以将常数10与特定查询的字段一起显示,这个10也可以换成表达式(1+1): 既然可以查1+1,那么一定也可以查询math+chinese+english: 这样,查询结果中的字段就存在math...实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物,所以无法回滚。...平时的各种sql优化好的语句都会将记录保存在bin log(持久化,保存在文件中),redo log中;undo log是用来做事务回滚的,以及事务的隔离性。
MySQL表的增删改查(基础) 据库最主要的操作就是增(create)删(update)改(retrieve)查(delete)。(CURD) 注意:进行增删改查操作的时候,请务必选中数据库。...在MySQL中,当前一次插入一条记录,分10次插入,效率要远低于一次把10个记录一起插入。因为MySQL是一个“客户端服务器”结构的程序。 原因: 由于网络请求和响应的时间开销引起的。...如果想要降序,那么手动指定desc(descend 降序)注意和上文desc(describe)表名区别。 MySQL中数据量是非常大的,因此有可能采用的是归并排序。...先把数据库中保存的数据,进行查询,查的时候,每次得到一行,就带入到条件中。 加入or就可以带上空值了。很多sql字句都是可以相互组合的。 这里是两个列进行比较。...比如: 这取决于mysql内部的实现。mysql里执行查询操作的时候,现针对每一行记录,计算条件,并按照条件筛选。满足条件的记录,才会取出对应的列。
三个文件 2.查看表 身处某个数据库中,可以通过 show tables 查看当前数据库中有哪些表 mysql> show tables; 当前数据库中就只有之前创建的两张表 2.1.查看表结构 知道有哪些表后...,还需要进一步了解表的 结构 信息,比如有哪些字段,才能知道如何使用这张表,查看表的详细信息语法为 DESC tablename 分别查看刚才创建的两张表的 结构 信息 mysql> desc person...a, drop b, drop c; 刚刚新增的无用字段立马就被删除了 在 MySQL 中,删除 一直都是一个 高危 操作,毕竟数据丢了不容易找回,比如这里的删除字段,如果表中有数据,那么表中数据关于该字段的信息会被全部删除...中对应的文件名也会被修改 注意: 如同修改字段名一样,修改表名也是一个危险操作,同样会影响上层使用 修改 person 表名为 students mysql> alter table person rename...删除 goods 表 mysql> drop table goods; 当然,删除成功后,Linux 中对应的文件也被删除了 写在最后:「修改字段、删除字段、修改字段名、修改表名、删除表」这些都是敏感操作
用例:创建一张学生表 -- 创建一张学生表 DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT, sn INT comment...VARCHAR(20) comment '姓名', qq_mail VARCHAR(20) comment 'QQ邮箱' ); 单行数据+全列插入 -- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致...用例: -- 创建考试成绩表 DROP TABLE IF EXISTS exam_result; CREATE TABLE exam_result ( id INT, name VARCHAR...指定列查询 -- 指定列的顺序不需要按定义表的顺序来 SELECT id, name, math FROM exam_result; ?...[LIMIT ...] -- 删除表中某一数据 DELETE FROM 数据表名 WHERE 条件; -- 删除整表数据 DELETE FROM 数据库名; ?
正因为主键和unique都有先查询的过程,MySQL就会默认给primary key和unique 这样的列,自动添加索引,来提高查询速度。...注意: 实际开发中,大部分的表,一般都会带有一个主键,主键往往是一个整数表示的id 在mysql中,一个表里,只能有一个主键,不能有多个 虽然主键不能有多个,mysql允许把多个列放到一起共同作为一个主键...(联合主键) 主键另外一个非常常用的方法,就是使用mysql自带的“自增主键”作为主键的值。...mysql的数据量比较小,所有的数据都在一个mysql服务器上,自增主键是可以很好地工作的,如果mysql的数据量很大,一台主机放不下就需要进行分库分表,使用多个主机来进行存储。...针对这种关系: student(id,name); class(class,name,studentIds); 注意:这种在MySQL中不可行,因为MySQL中没有一个像数组这样的类型。
确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。 FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。...对于MySQL数据库,对CHECK子句进行分析,但是忽略CHECK子句。...,语法: foreign key (字段名) references 主表(列) 用例: -- 创建班级表,有使用MySQL关键字作为字段时,需要使用``来标识 DROP TABLE IF EXISTS...内连接 语法: select 字段 from 表1 别名1 [inner] join 表2 别名2 on 连接条件 and 其他条件; select 字段 from 表1 别名1,表2 别名2 where...-- 左外连接,表1完全显示 select 字段名 from 表名1 left join 表名2 on 连接条件; -- 右外连接,表2完全显示 select 字段 from 表名1 right join
1.如果表定义了PK(Primary Key,主键),那么PK就是聚集索引。 2.如果表没有定义PK,则第一个NOT NULL UNIQUE的列就是聚集索引。...假设有这么个表: id是主键,name是普通索引。 则: 聚集索引是这样的存储方式: 普通索引自立门户,是这么个存储方式: 那么局势就崭露头角了哈,脑子活的已经晓得了。...称之为回表查询。 不是所有索引都有资格当覆盖索引的,因为覆盖索引必须要存储索引的列值,而哈希索引、空间索引和全文索引等都不存储索引列值,索引MySQL只能使用B-Tree索引做覆盖索引。
二、什么是回表查询?...通俗的讲就是,如果索引的列在 select 所需获得的列中(因为在 mysql 中索引是根据索引列的值进行排序的,所以索引节点中存在该列中的部分值)或者根据一次索引查询就能获得记录就不需要回表,如果 select...就像上面的两个查找过程就是回表了。 四、解决办法 使用覆盖索引可以解决上面所说的回表的问题。...五、更多如下图: (1)先通过普通索引定位到主键值id=5; (2)在通过聚集索引定位到行记录; 这就是所谓的回表查询,先定位主键值,再定位行记录,它的性能较扫一遍索引树更低。...六、总结 使用聚集索引(主键或第一个唯一索引)就不会回表,普通索引就会回表。
回表查询 执行下面sql查询 select id,name from user where age = 10; 分析查询过程, 首先通过普通索引(age) 定位 age = 10 的ID 然后通过聚集索引...索引覆盖 执行下面sql查询 select id,age from user where age = 10; 可通过普通索引列(age) 就能获取SQL所需的所有列数据,无需回表,速度更快。...查询优化 列查询回表优化 分页查询 4....where子句的数据返回 ,此过程需要回表 Mysql版本 >= 5.6 检索复合索引 idx_name_age 查询所有 name 包含 “张” 的 且age =20 的数据 直接返回结果集, 无需回表...可见 索引下推在非主键索引上的优化,可以有效减少回表的次数,大大提升了查询的效率 explain 分析: Using Index Condition 使用了索引下推的表现 end!
ALTER TABLE 旧表名 RENAME 新表名; 此语句可以修改表的名称,其实一般我们在终端中使用,有可视化工具完全没必要用命令。...ALTER TABLE stu DROP demo; -- ALTER TABLE 表名 DROP 字段名; 添加主键约束 -- ALTER TABLE 表名 ADD CONSTRAINT 自定义主键名...但是最好按规范来,pk+下划线+表名,如:PK_STU`。...表里面,外键表是result,不要搞反了。...外键名规范是FK_表1_表2。 小知识 我们发现,我们上面的语句常用ALTER TABLE这个关键字。 我们可以常识查看帮助文档。 如果英语不咋地,就老老实实搜浏览器吧。
打开数据库: 步骤:新建查询(Ctrl+Q)→写SQL语句→运行→刷新→创建表成功 ①新建查询(Ctrl+Q) ②写SQL语句: 创建表的SQL语句一般格式: CREATE TABLE...( [列级完整性约束定义] {, [列级完整性约束定义] … } [,表级完整性约束定义] ) 下面来举个列子来说明一下就更清晰了,比如我需要创建一个...Student表: CREATE TABLE Student( Sno char(7) PRIMARY KEY, Sname char(10) NOT NULL, Ssex char(2), Sage...tinyint, Sdept char(20) ) 顺便把图也附上: ③运行,然后刷新 最后运行,再刷新一下,表就出来了。
本页目录 库语句 建库 修改库字符集 指定库排序规则 当前库状态的建表语句 删除库 Navicat编辑数据库时执行的SQL 表语句 建表 添加字段 修改表 修改字段 修改表字符集、排序规则 截断表 删除表...添加索引 一直都是用MySQL可视化工具,几乎没碰过建库、表等语句了。...我们无法人为控制,只能建库完毕后执行修改库字符集或者建库前修改MySQL配置 CREATE DATABASE IF NOT EXISTS `school` DEFAULT CHARACTER SET...直接执行就行,没有参数 SELECT @@character_set_database, @@collation_database 表语句 建表 添加字段 修改表 修改字段 修改表字符集、排序规则 截断表...删除表 添加索引
回表 在研究mysql二级索引的时候,发现Mysql回表这个操作,往下研究了一下 字面意思,找到索引,回到表中找数据 解释一下就是: 先通过索引扫描出数据所在的行,再通过行主键ID 取出数据。...另外回表的产生也是需要一定条件的,如果一次索引查询就能获得所有的select 记录(也就是联合索引已经包含了你查的字段)就不需要回表,如果select 所需获得列中有其他的非索引列,就会发生回表动作。...) 索引下推 索引下推(index condition pushdown )简称ICP,在Mysql5.6以后的版本上推出,用于优化回表查询; 在不使用ICP的情况下,在使用非主键索引(又叫普通索引或者二级索引...然后通过id在聚簇索引上回表找到对应的age数据,将结果存放在临时表中; 4. 最后在临时表中通过age条件来筛选数据。 以上过程会扫描4条记录,回表4次。...总结: 索引下推功能是mysql 5.6推出优化回表的操作,只支持向上兼容,低版本是不支持的; 索引下推优化的只是回表次数,扫描行数还是一样的。
在一个业务功能中要求先清空一张基础表(user表)再插入一批新数据。 在删除过程中报错为其它表有外键引用,无法删除。 于是,查询库中哪些表引用了 user 表中的主键为外键。...从 INFORMATION_SCHEMA.KEY_COLUMN_USAGE 表中查。...select * from INFORMATION_SCHEMA.KEY_COLUMN_USAGE where REFERENCED_TABLE_NAME='被引用表的表名' 如图 红色框中是当前连接中的数据库...,黄框中的是引用了 user 表为外键的其它表,蓝色框中的是黄框中表的外键字段。...要想删除 user 表中的数据,就要先删除后面 2 个框中的外键引用。
CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写. 2.新增(Create) 语法: insert into 表名 values...下面以一张学生表为例; 2.1 单行数据 + 全列插入 -- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致 INSERT INTO student VALUES (100...查询 首先创建一张表,并插入一些数据作为案例; -- 创建考试成绩表 DROP TABLE IF EXISTS exam_result; //如果之前创建过这个名字的表就删除掉 CREATE...DROP TABLE IF EXISTS test; -- 删除整表数据 DELETE FROM for_delete; 注意:在这里使用drop关键字,删除的是整张表,而用delete关键字...,删除的是表的内容,表的结构还在.
列2 from 表名;(*代表查询所有的列) 例子: mysql> select id,name from u1; +------+----------...alter table 旧表名 rename 新表名; mysql> alter table u6 rename hello; Query OK, 0 rows affected (0.16 sec)...方式一 show tables;查看该数据库内所有的列表 方式二 show create table 表名;查看具体表结构的详细信息 mysql> show create table hello; +...id<=2 and id=3; Query OK, 0 rows affected (0.00 sec) 3.2.2删除整个表所有的数据 1.delete from 表名; mysql> delete...> select * from u4; Empty set (0.00 sec) 2.truncate 表名; mysql> select * from u4; Empty set (0.00 sec)
在上一小节中介绍了 MySQL 数据库的一些最最最基础的入门级也是必须要掌握的10条语句,本节将继续深入学习 MySQL 的增删改查语句。本节讲的增删改查是相对于表 而言的。...1、准备工作 想要对表进行增删改查,首先应该有张表,假设我们要统计大学同学工作之后的工作情况,建立了如下表格: 姓名 性别 公司 工资 准备工作: mysql> create...2.1 添加所有列的数据 下面向该表中添加几条数据: mysql> insert into class (id,name,gender,company,salary) -> values (1,...06.插入数据多条记录 3、delete 删除记录 要从表中删除数据,请使用MySQL delete语句。...12.查询指定行的指定列 至此数据库的增删改查的基本语法都已介绍了,当然增删改查还有高级的用法,以后有机会讲到。
前言 前面我们学习了MySQL数据库和数据表的创建、删除。接下来我们就需要将数据保存在数据表中。今天我们就来学习数据表的增删查改(CRUD)。...新增(Create) 一旦创建数据库和数据表,下一步就是向数据表中添加数据。MySQL 通过 insert 语句来添加一条或多条数据。...语法格式: insert into 表名 values (表达式, ...., 表达式); 示例:创建学生表 -- 创建学生表 id create table student(id int, name...查询(Retrieve) MySQL 通过 select 语句来查询数据,查询结果通常会生成一个临时表。...; -- 表中列名=别名 select id,name,chinese+math+english as 总分 from result; 2.5 去重 MySQL 使用 distinct关键字对某列数据进行去重
领取专属 10元无门槛券
手把手带您无忧上云