MYSQL排序加分页报错Out of sort memory, consider increasing server sort buffer size

前言

出现该问题的是在做分页查询时出现的,确切的说是order by 和 limit一起用的时候出现的。而起是由于limit m,n 中m过大时会出现Out of sort memory, consider increasing server sort buffer size

解决

SHOW variables like ‘%sort_buffer_size%’

在这里插入图片描述

通过命令查询后,发现默认的sort_buffer_size大小为262144(也就是256Kb);

所以,我们需要修改这个值,将这个值是介于256kb-2M之间,我们将其设置为1M。设置过大连接多的时候,占用的内存也会很大。

SET SESSION sort_buffer_size = 1024 * 1024; – 修改当前session连接的值
SET GLOBAL sort_buffer_size = 1024 * 1024;-- 修改全局变量的值;

方案

方案一:直接修改配置文件

vi /etc/my.cnf
[mysqld]
sort_buffer_size = 1048576 

重启服务

service mysqld restart

方案二:在命令行里通过SET来设置,然后再修改参数文件

如果要修改全局变量,必须要显示指定"GLOBAL"或者"@@global.",同时必须要有SUPER权限.

SET GLOBAL sort_buffer_size = 1024*1024

如果查询时使用的是show variables的话,会发现设置并没有生效,除非重新登录再查看.这是因为使用show variables的话就等同于使用show session variables,查询的是会话变量,只有使用show
global variables查询的才是全局变量.如果仅仅想修改会话变量的话,可以使用类似sort_buffer_size =1048576 ;或者set sort_buffer_size =1048576 ;这样的语法.

当前只修改了正在运行的MySQL实例参数,但下次重启mysqld又会回到默认值,所以别忘了修改参数文件:

vi /etc/my.cnf
[mysqld]
sort_buffer_size =1048576 

总结

一定记得,通过命令设置了全局变量后,要在配置文件中做修改,否则重启服务后,设置的全局变量就失效了。