MySQL-索引相关面试题

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 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;
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
SQL 关系型数据库 MySQL
深入解析MySQL的EXPLAIN:指标详解与索引优化
MySQL 中的 `EXPLAIN` 语句用于分析和优化 SQL 查询,帮助你了解查询优化器的执行计划。本文详细介绍了 `EXPLAIN` 输出的各项指标,如 `id`、`select_type`、`table`、`type`、`key` 等,并提供了如何利用这些指标优化索引结构和 SQL 语句的具体方法。通过实战案例,展示了如何通过创建合适索引和调整查询语句来提升查询性能。
35 9
|
4天前
|
存储 SQL 关系型数据库
MySQL进阶突击系列(03) MySQL架构原理solo九魂17环连问 | 给大厂面试官的一封信
本文介绍了MySQL架构原理、存储引擎和索引的相关知识点,涵盖查询和更新SQL的执行过程、MySQL各组件的作用、存储引擎的类型及特性、索引的建立和使用原则,以及二叉树、平衡二叉树和B树的区别。通过这些内容,帮助读者深入了解MySQL的工作机制,提高数据库管理和优化能力。
|
1月前
|
缓存 关系型数据库 MySQL
MySQL索引策略与查询性能调优实战
在实际应用中,需要根据具体的业务需求和查询模式,综合运用索引策略和查询性能调优方法,不断地测试和优化,以提高MySQL数据库的查询性能。
|
1月前
|
SQL 关系型数据库 MySQL
大厂面试官:聊下 MySQL 慢查询优化、索引优化?
MySQL慢查询优化、索引优化,是必知必备,大厂面试高频,本文深入详解,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验分享。
大厂面试官:聊下 MySQL 慢查询优化、索引优化?
|
7天前
|
缓存 关系型数据库 MySQL
MySQL 索引优化以及慢查询优化
通过本文的介绍,希望您能够深入理解MySQL索引优化和慢查询优化的方法,并在实际应用中灵活运用这些技术,提升数据库的整体性能。
47 18
|
6天前
|
缓存 关系型数据库 MySQL
MySQL 索引优化以及慢查询优化
通过本文的介绍,希望您能够深入理解MySQL索引优化和慢查询优化的方法,并在实际应用中灵活运用这些技术,提升数据库的整体性能。
17 7
|
5天前
|
缓存 关系型数据库 MySQL
MySQL 索引优化与慢查询优化:原理与实践
通过本文的介绍,希望您能够深入理解MySQL索引优化与慢查询优化的原理和实践方法,并在实际项目中灵活运用这些技术,提升数据库的整体性能。
26 5
|
9天前
|
存储 关系型数据库 MySQL
Mysql索引:深入理解InnoDb聚集索引与MyisAm非聚集索引
通过本文的介绍,希望您能深入理解InnoDB聚集索引与MyISAM非聚集索引的概念、结构和应用场景,从而在实际工作中灵活运用这些知识,优化数据库性能。
55 7
|
25天前
|
关系型数据库 MySQL Java
MySQL索引优化与Java应用实践
【11月更文挑战第25天】在大数据量和高并发的业务场景下,MySQL数据库的索引优化是提升查询性能的关键。本文将深入探讨MySQL索引的多种类型、优化策略及其在Java应用中的实践,通过历史背景、业务场景、底层原理的介绍,并结合Java示例代码,帮助Java架构师更好地理解并应用这些技术。
25 2
|
1月前
|
SQL 关系型数据库 MySQL
阿里面试:1000万级大表, 如何 加索引?
45岁老架构师尼恩在其读者交流群中分享了如何在生产环境中给大表加索引的方法。文章详细介绍了两种索引构建方式:在线模式(Online DDL)和离线模式(Offline DDL),并深入探讨了 MySQL 5.6.7 之前的“影子策略”和 pt-online-schema-change 方案,以及 MySQL 5.6.7 之后的内部 Online DDL 特性。通过这些方法,可以有效地减少 DDL 操作对业务的影响,确保数据的一致性和完整性。尼恩还提供了大量面试题和解决方案,帮助读者在面试中充分展示技术实力。