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 

总结

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

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值