mysql排序

全字段排序

我们经常使用order by对数据进行排序,它的内部执行过程,为了避免全表扫描,给条件字段设置索引,根据索引知道ID值,通过ID索引找到整行数据,数据放入mysql在内存中准备的sort buffer,根据name字段为这些数据排序,最终只要前1000行的数据。

csharp 复制代码
select city,name,age from t where city='杭州' order by name limit 1000  ;

sort_buffer_size

按照字段排序数据,mysql提供了sort_buffer_size,如果要排序的数据量小于它,就在内存中排序。如果大于,就在外部磁盘临时文件排序。

number_of_tmp_files

临时文件数量,把所有的数据分成好几份,排好序后放入临时文件,有序文件合并成一个大的有序大文件。

rowid排序

如果sort_buffer里面的字段太多,内存放不下,字段会占用多个临时文件,磁盘需要分配更多的临时文件。性能会变差。

max_length_for_sort_data

如果单行数据长度超过我们设定的max_length_for_sort_data值,sort_buffer字段就要减少,只留下排序字段和ID组成sort_buffer。利用排序字段排好序,通过ID获取前1000行数据,抽取我们要的字段组成结果集。

选择哪个合适

我们寄希望于所有的数据都能在内存中完成所有操作,内存越大越好,减少磁盘访问。如果内存特别小,我们只能使用rowid排序算法。

如果我们想取消在临时空间排序数据这一步,我们要保证我们的数据已经提前排好序。为这些字段建立一个索引,使用覆盖索引方式,我们不用再回表查询主键索引获取数据,索引的信息已经满足我们的需求。

相关推荐
计算机毕设vx_bysj68693 小时前
【免费领源码】77196基于java的手机银行app管理系统的设计与实现 计算机毕业设计项目推荐上万套实战教程JAVA,node.js,C++、python、大屏数据可视化
java·mysql·智能手机·课程设计
吴声子夜歌3 小时前
ES6——正则的扩展详解
前端·mysql·es6
xixingzhe23 小时前
Mysql统计空间增量
数据库·mysql
程序员萌萌4 小时前
Java之mysql实战讲解(三):聚簇索引与非聚簇索引
java·mysql·聚簇索引
cozil5 小时前
记录mysql创建数据库未指定字符集引发的问题及解决方法
数据库·mysql
AC赳赳老秦5 小时前
OpenClaw数据库高效操作指南:MySQL/PostgreSQL批量处理与数据迁移实战
大数据·数据库·mysql·elasticsearch·postgresql·deepseek·openclaw
ego.iblacat5 小时前
Python 连接 MySQL 数据库
数据库·python·mysql
阿丰资源7 小时前
SpringBoot+MySQL+MyBatis-Plus+Vue前后端分离仓库管理系统 (附资料)
spring boot·mysql·mybatis
阿华田5128 小时前
MySQL性能优化大全
数据库·mysql·性能优化
被摘下的星星8 小时前
MySQL 别名使用规则详解
数据库·mysql