数据量大查询慢?索引让你的SQL秒级响应!|转行学DB第9天

本文涉及的产品
RDS Agent(兼容OpenClaw),2核4GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 用生活化比喻(如字典目录)详解索引原理:它通过B+树结构加速查询,避免全表扫描;涵盖创建、查看、删除索引方法,联合索引的最左前缀原则,以及读写平衡等实战要点——让查询从“等几秒”变“秒出”!

大家好呀!我是数据库小学妹👋

前几篇我们学会了各种查询技巧:单表查、多表连、分组统计、子查询嵌套。但随着查询的数据越来越多,我就发现:

同样一条查询,数据少的时候秒出,数据多了居然要等好几秒!有没有办法让查询变快?

当然是有的!今天给大家分享的就是这个可以让查询速度飞起来的神器——“​索引​”。它就像书的目录,能帮数据库快速找到目标数据,而不是一页页翻。

一、没有索引是什么体验?

想象一下,你拿到一本​没有目录​、没有拼音索引的《新华字典》。想查“数据库”三个字是什么意思,你只能从第一页开始,一行一行往下看……

这就是​全表扫描​:数据库把整张表的每一行都翻一遍,直到找到匹配的数据。数据量小的时候无所谓,一旦有几十万、几百万行,就会慢到怀疑人生。

索引就是给数据建的“目录”或“拼音索引”。有了它,数据库可以像查字典一样,先定位到大概位置,再快速找到目标。

💡 索引的本质是一种​数据结构(​MySQL里通常是B+树),它能帮助数据库​跳过大量无关数据​,直接定位到目标行。

二、索引长什么样?

假设有一张用户表 users,没有索引时想查 name = '小明',数据库会一行一行对比。

id name age city
1 张三 20 北京
2 李四 21 上海
3 小明 22 深圳
... ... ... ...

name 列加上索引后,数据库会维护一个​按字母排序的目录​:

name 所在位置(行号/地址)
李四 2
小明 3
张三 1

现在查 name = '小明',数据库先去目录里找到“小明”,然后直接跳到第3行,​不需要翻其他行​。

这就是索引加速的原理。

三、怎么创建和使用索引?

1. 创建索引

CREATE INDEX idx_name ON users (name);
  • idx_name 是索引的名字(随便起,但最好有意义)
  • users 是表名
  • (name) 是对哪一列建索引

2. 查看表的索引

SHOW INDEX FROM users;

3. 删除索引

DROP INDEX idx_name ON users;

4. 创建唯一索引(值不能重复)

CREATE UNIQUE INDEX idx_phone ON users (phone);

四、什么时候该用索引?什么时候不该用?

💡 索引不是越多越好。每建一个索引,插入、更新、删除数据时都会多花时间维护索引。读写平衡很重要。

五、最左前缀原则:联合索引的小秘密

如果你经常同时用 nameage 作为条件:

SELECT * FROM users WHERE name = '小明' AND age = 22;

可以建​联合索引​:

CREATE INDEX idx_name_age ON users (name, age);

这里需要注意:联合索引遵循​最左前缀原则​。意思是,查询条件必须从索引的最左边列开始才能用到索引。

  • WHERE name = '小明' → 用到索引
  • WHERE name = '小明' AND age = 22 → 用到索引
  • WHERE age = 22 → ​用不到索引​(因为没有从最左列 name 开始)

所以建联合索引时,要把最常用的筛选列放在最左边。

六、新手避坑指南(血泪总结)

七、今日学习心得

今天的内容总结成三句话:

  1. 索引就是书的目录​,帮数据库快速定位数据,避免全表扫描
  2. 不是越多越好​,适合经常作为 WHEREJOINORDER BY 的列
  3. 联合索引注意最左前缀​,从最常用的列开始

以前不知道索引的时候,觉得“查询慢就慢呗,等等就好了”。现在学会用 EXPLAIN 查看执行计划,看到 type 列从 ALL(全表扫描)变成 ref(使用索引),那种成就感,就像给自行车装上了发动机。

👋 我是​数据库小学妹​,一个从设计转行数据库的菜鸟。 我们一起,把复杂的技术变得简单有趣!💕


本文为个人学习总结,所有命令均在MySQL​ 8.0环境下验证。索引是把双刃剑,合理使用才能让查询飞起来。

相关文章
|
2月前
|
SQL 安全 关系型数据库
MySQL避坑指南:从逻辑备份到物理备份,新手必看的救命稻草。
数据库小学妹带你轻松应对误删!用`mysqldump`逻辑备份+`mysql`命令快速恢复,安全、简单、零门槛——备份不是可选项,而是DBA的保命符!
|
2月前
|
SQL 关系型数据库 MySQL
子查询:让SQL像俄罗斯套娃一样嵌套!|转行学DB第8天
数据库小学妹带你轻松入门子查询!用“SELECT里套SELECT”,像俄罗斯套娃一样,一步解决“先算平均分、再查高分学生”等两步难题。支持WHERE(条件筛选)、FROM(临时表)、SELECT(标量列)三种用法,简洁直观,新手友好~
|
2月前
|
SQL 数据库
多表关联查询入门:LEFT JOIN、INNER JOIN一文搞懂|转行学DB第6天
本文通俗易懂地讲解了数据库多表查询的三种JOIN操作:INNER JOIN(内连接)只返回两表匹配的数据,适用于查询交集数据;LEFT JOIN(左连接)保留左表所有记录并匹配右表数据,适用于查询主表完整信息;RIGHT JOIN(右连接)则保留右表所有记录。
|
2月前
|
SQL 关系型数据库 MySQL
主键、外键和约束:让数据库“有规矩”才能不出错!|转行学DB第5天
本文用通俗易懂的语言讲解了主键(数据的唯一标识)、外键(表间关联)以及唯一约束、非空约束等其他常见约束规则。通过具体SQL示例展示了各种约束的使用方法,并分享了新手容易踩的坑和实用建议。
|
2月前
|
缓存 网络协议 API
如何查询IPv6地址的归属信息?命令行、在线工具、API接口全解析
本文详解IPv6地址查询的四大实用方案(命令行、在线控制台、API接口、本地离线库),剖析其精度、速度与适用场景,并提供选型建议及CDN调度、安全防护、地域分析等实战案例,助力高效精准获取IPv6归属信息。(239字)
819 7
|
2月前
|
SQL NoSQL 关系型数据库
数据库分类一次讲清|转行学DB第2天
数据库小学妹(UI转行萌新)用通俗语言拆解数据库分类:从关系型(MySQL/Oracle)、NoSQL(Redis/MongoDB/Cassandra)、NewSQL(TiDB)到2026年爆火的向量数据库(Pinecone/Milvus),按数据模型、部署架构、业务负载三大维度梳理,配场景化案例与选学路径,助新手轻松入门。
|
2月前
|
存储 JSON 缓存
告别数据混乱!数据库设计三范式从入门到实践
数据库小学妹带你轻松入门三范式!用“建房打地基”比喻,讲清1NF(列不可分)、2NF(消除部分依赖)、3NF(消除传递依赖),直击数据冗余、更新异常等痛点。附实战拆表案例与反范式化提醒,助你设计出结构清晰、稳定高效的数据库!
|
29天前
|
SQL 关系型数据库 MySQL
MySQL慢查询诊断实战:从10秒到0.1秒,我的5步排障法
数据库小学妹分享慢查询优化实战:从10秒降至0.08秒!详解「发现→收集→分析→优化→验证」5步排障法,覆盖慢日志配置、EXPLAIN进阶、索引失效场景、JOIN与分页优化等核心技巧,附真实案例与速查表。
|
2月前
|
存储 人工智能 关系型数据库
阿里云数据库产品活动:上云优选,RDS年付88元起!多款云数据库产品免费试用
阿里云2026年数据库产品活动更新,覆盖RDS、PolarDB、NoSQL及数据仓库全系产品,提供从3折起的超值折扣、新老用户同享的专属福利及免费试用机会。活动涵盖2核4GB至8核16GB多规格配置,RDS 年付88元起!更有续费/升级享5-6折优惠。
542 4
|
1月前
|
canal 缓存 NoSQL
数据库扛不住高并发?Redis缓存+双写一致性:给你的系统装上“涡轮增压”
数据库小学妹带你破解Redis缓存一致性难题!面对高并发,如何确保Redis与数据库数据同步?详解“先更库后删缓”“延时双删”“Binlog异步同步”等4大方案,直击雪崩、击穿、穿透三座大山,助你构建又快又稳的数据库架构.