MySQL索引优化之分页探索
2023-06-13 09:12:13 时间
MySQL
索引优化之分页探索
表结构
CREATE TABLE `demo` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '' COMMENT '姓名',
`age` int(11) NOT NULL DEFAULT '0' COMMENT '年龄',
`position` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '' COMMENT '职位',
`card_num` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '工卡号',
PRIMARY KEY (`id`),
KEY `index_union` (`name`,`age`,`position`)
) ENGINE=InnoDB AUTO_INCREMENT=450003 DEFAULT CHARSET=utf8;
450003条数据
limit分页执行情况
像select * from demo limit 90000,10;考虑到回表,所以mysql干脆选择全表扫描。mysql不是直接
从第90000行开始计算10条,而是从第一个叶子节点开始计数,计算90010行。
案例一
针对上图,当id是连续自增的时候,可以用主键筛选出id=90000之后的数据。因为主键的索引是B+树结构,本身就是有序的。
案例二
先按照name排序,然后再从第90000行起找10行,虽然name是索引,但select的列在index_union索引
树上并没有保存。所以还会涉及到回表,于是mysql直接选择扫主键索引树的叶子结点,先将40多万数据根据name
排好序,然后计算90000行+10行。
优化方法:利用子查询解决最消耗时间的排序和回表问题,联合索引树种保存有主键id,order by name的话
可以将name、age、position整个索引充分使用因为确定了最左列的排序,其余的俩列age、和position其实也是
排好序的了,通过Extra字段也可以是使用了索引树做排序。
最外层的查询是根据主键来关联的,所以几乎可以忽略。10+10 因为id是主键,可以直接拿临时表10条数据去扫。
相关文章
- mysql如何使用前缀索引_MySQL的前缀索引你是如何使用的[通俗易懂]
- node.js(5) MySQL数据库的学习
- 技术分享 | MySQL 覆盖索引优化案例一则
- 如何优化Mysql千万级快速分页,limit优化快速分页,MySQL处理千万级数据查询的优化方案详解数据库
- MySQL查询:实现子类查询(mysql查询子类)
- MySQL实例操作指南:简单、快速、高效(mysql实例操作)
- 重置MySQL密码重置:轻松完成充值(mysql充值密码)
- 使用bat脚本执行MySQL数据库操作(bat执行mysql语句)
- MySQL更改数据库密码的一步一步完整指引(mysql更改数据库密码)
- MySQL如何实现表空间扩充(mysql扩充表空间)
- MySQL锁表深度剖析(怎么看mysql锁表)
- MySQL 时间查询为利用者提供便捷服务(mysql按时间查询)
- MySQL数据库查询性能优化实战(mysql大数据查询优化)
- 过长MySQL: 优化锁等待时间的方法(mysql锁等待时间)
- 使用MySQL查询索引的技巧(mysql查索引)
- MySQL: 把缺失的补上(mysql没有就插入)
- MySQL数据库优化:索引的应用与使用(mysql数据库索引方式)
- MySQL建立索引的准则(mysql建索引的原则)
- MySQL 溢出:警惕系统的崩溃风险!(mysql溢出)
- MySQL函数创建与使用简介(mysql创建函数)
- 学习如何在MySQL中建立组合索引,提升查询效率(mysql建立组合索引)
- MySQL代码过长的优化方法汇总(mysql中代码太长)
- MySQL的SECOND函数时间处理必备之二(mysql中second)
- MySQL中C和M优化查询的关键技巧(mysql中 c 和 m)
- 技术MySQL索引技术中的B树应用(B树与MySQL索引)
- MySQL连接数上限突破一万,提升大数据处理能力(mysql一万条连接)
- 高效省事,MySQL优化技巧合并双重操作(mysql两次操作合并)
- MySQL上机题目及答案快速掌握MySQL基础知识(mysql上机题目及答案)
- Mysql,分布式,支持与否(mysql不支持分布式吗)