MySQL-索引相关面试题

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL-索引相关面试题

说出以下语法使用索引的情况

假设建立复合索引 (a、b、c),请说出以下条件是否使用到了索引及使用情况

语法 结果
where a = 4 使用到了索引 a
where a = 4 and b = 6 使用到了索引 a、b
where a = 4 and c = 5 and b = 6 使用到了 a、b、c
where b = 4 or b = 5 没有使用到索引
where a = 4 and c = 6 使用到了索引 a
where a = 4 and b > 5 and c = 6 使用到索引 a、b
where a = 4 and b like ‘test%’ and c = 4 使用到了 a、b kk% 相当于范围
where a = 4 order by b,c 使用到了 a,不会有 filesort
where b = 5 order by a 没用到索引,会有 filesort
where b = 5 order by c 没有索引,会有 filesort
where a = 5 group by c,b 使用到了索引 a, 造成 Using temporary

大批量数据时分页操作如何优化

批量插入数据

建立表

DROP TABLE
IF EXISTS `testtestemployee`;
CREATE TABLE `testtestemployee` (
  `id` INT (11) NOT NULL AUTO_INCREMENT,
  `name` VARCHAR (20) DEFAULT NULL,
  `dep_id` INT (11) DEFAULT NULL,
  `age` INT (11) DEFAULT NULL,
  `salary` DECIMAL (10, 2) DEFAULT NULL,
  `cus_id` INT (11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE = INNODB AUTO_INCREMENT = 109 DEFAULT CHARSET = utf8;

随机生成字符串

#随机生成一个指定个数的字符串
delimiter $$
CREATE FUNCTION rand_str (n INT) RETURNS VARCHAR (255)
BEGIN
  #声明一个str 包含52个字母
DECLARE str VARCHAR (100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ' ; #记录当前是第几个
DECLARE i INT DEFAULT 0 ; #生成的结果
DECLARE res_str VARCHAR (255) DEFAULT '' ;
WHILE i < n DO
SET res_str = CONCAT(
  res_str,
  substr(str, floor(1 + RAND() * 52), 1)
) ;
SET i = i + 1 ;
END
WHILE ; RETURN res_str ;
END$$ 
delimiter ;


SET GLOBAL log_bin_trust_function_creators = TRUE

批量插入数据

delimiter $$
CREATE PROCEDURE insert_emp (IN max_num INT)
BEGIN
DECLARE i INT DEFAULT 0 ;
SET autocommit = 0 ;
REPEAT
SET i = i + 1 ; INSERT INTO testtestemployee (
  NAME,
  dep_id,
  age,
  salary,
  cus_id
)
VALUES
  (
    rand_str (5),
    floor(1 + rand() * 10),
    floor(20 + rand() * 10),
    floor(2000 + rand() * 10),
    floor(1 + rand() * 10)
  ) ; UNTIL i = max_num
END
REPEAT
  ; COMMIT ;
END$$
delimiter ;

传统分析查询

使用 limit 随着 offset 增大,查询的速度会越来越慢,会把前面的数据都取出,找到对应位置

优化后分页查询

使用子查询优化

SELECT
  *
FROM
  testemployee e
INNER JOIN (
  SELECT
    id
  FROM
    testemployee
  LIMIT 500000,
  10
) et ON e.id = et.id


SELECT
  *
FROM
  testemployee
WHERE
  id >= (
    SELECT
      id
    FROM
      testemployee
    LIMIT 500000,
    1
  )
LIMIT 10

使用 id 限定优化

记录上一页最大的 id号 使用范围查询,限制是只能使用于明确知道 id 的情况,不过一般建立表的时候,都会添加基本的id字段,这为分页查询带来很多便利

SELECT
  *
FROM
  testemployee
WHERE
  id BETWEEN 1000000
AND 1000100
LIMIT 100;
SELECT
  *
FROM
  testtestemployee
WHERE
  id >= 1000001
LIMIT 100;
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 MySQL
深入解析MySQL的EXPLAIN:指标详解与索引优化
MySQL 中的 `EXPLAIN` 语句用于分析和优化 SQL 查询,帮助你了解查询优化器的执行计划。本文详细介绍了 `EXPLAIN` 输出的各项指标,如 `id`、`select_type`、`table`、`type`、`key` 等,并提供了如何利用这些指标优化索引结构和 SQL 语句的具体方法。通过实战案例,展示了如何通过创建合适索引和调整查询语句来提升查询性能。
174 9
|
1月前
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
16天前
|
SQL 存储 关系型数据库
MySQL秘籍之索引与查询优化实战指南
最左前缀原则。不冗余原则。最大选择性原则。所谓前缀索引,说白了就是对文本的前几个字符建立索引(具体是几个字符在建立索引时去指定),比如以产品名称的前 10 位来建索引,这样建立起来的索引更小,查询效率更快!
78 22
 MySQL秘籍之索引与查询优化实战指南
|
10天前
|
存储 SQL 关系型数据库
MySQL 面试题
MySQL 的一些基础面试题
|
18天前
|
存储 关系型数据库 MySQL
MySQL中为什么要使用索引合并(Index Merge)?
通过这些内容的详细介绍和实际案例分析,希望能帮助您深入理解索引合并及其在MySQL中的
68 10
|
1月前
|
缓存 关系型数据库 MySQL
MySQL 索引优化以及慢查询优化
通过本文的介绍,希望您能够深入理解MySQL索引优化和慢查询优化的方法,并在实际应用中灵活运用这些技术,提升数据库的整体性能。
79 18
|
30天前
|
存储 Oracle 关系型数据库
索引在手,查询无忧:MySQL索引简介
MySQL 是一款广泛使用的关系型数据库管理系统,在2024年5月的DB-Engines排名中得分1084,仅次于Oracle。本文介绍MySQL索引的工作原理和类型,包括B+Tree、Hash、Full-text索引,以及主键、唯一、普通索引等,帮助开发者优化查询性能。索引类似于图书馆的分类系统,能快速定位数据行,极大提高检索效率。
59 8
|
1月前
|
缓存 关系型数据库 MySQL
MySQL 索引优化以及慢查询优化
通过本文的介绍,希望您能够深入理解MySQL索引优化和慢查询优化的方法,并在实际应用中灵活运用这些技术,提升数据库的整体性能。
74 7
|
1月前
|
缓存 关系型数据库 MySQL
MySQL 索引优化与慢查询优化:原理与实践
通过本文的介绍,希望您能够深入理解MySQL索引优化与慢查询优化的原理和实践方法,并在实际项目中灵活运用这些技术,提升数据库的整体性能。
102 5
|
25天前
|
存储 关系型数据库 MySQL
【MYSQL】 ——索引(B树B+树)、设计栈
索引的特点,使用场景,操作,底层结构,B树B+树,MYSQL设计栈

热门文章

最新文章