MySQL-索引相关面试题

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 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;
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
JSON 关系型数据库 MySQL
✅MySQL用了函数到底会不会导致索引失效
MySQL 8.0 引入了函数索引,打破了传统观念,允许在索引中使用函数,提升查询性能。通过创建基于表达式的索引,如 `CONCAT`、`SUBSTRING_INDEX`、`YEAR`、`MONTH` 等,可以优化涉及这些函数的查询。虽然提高了某些查询速度,但也会增加数据维护成本。应谨慎使用,确保表达式确定且适用于常见查询模式。示例包括基于字符串、日期、数学运算和JSON属性的索引。
✅MySQL用了函数到底会不会导致索引失效
|
2天前
|
SQL 关系型数据库 MySQL
java面试之MySQL数据库篇
java面试之MySQL数据库篇
6 0
java面试之MySQL数据库篇
|
2天前
|
SQL 关系型数据库 MySQL
mysql面试之分库分表总结
mysql面试之分库分表总结
11 0
|
2天前
|
关系型数据库 MySQL 数据库
MySQL索引的类型与优化方法
MySQL索引的类型与优化方法
|
4天前
|
存储 关系型数据库 MySQL
MySQL索引设计原则与优化策略
MySQL索引设计原则与优化策略
|
4天前
|
关系型数据库 MySQL 数据库
MySQL索引的类型与优化方法
MySQL索引的类型与优化方法
|
5天前
|
存储 关系型数据库 MySQL
MySQL索引设计原则与优化策略
MySQL索引设计原则与优化策略
|
5天前
|
存储 关系型数据库 MySQL
MySQL删除索引的方法与注意事项
MySQL删除索引的方法与注意事项
|
6天前
|
关系型数据库 MySQL Java
MySQL索引设计与性能优化策略详解
MySQL索引设计与性能优化策略详解
|
10天前
|
存储 关系型数据库 MySQL
MySQL 索引优化:深入探索自适应哈希索引的奥秘
MySQL 索引优化:深入探索自适应哈希索引的奥秘