我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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 

总结

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

来源地址:https://blog.csdn.net/Mrzhang567/article/details/126490909

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL报Out of sort memory, consider increasing server sort buffer size的两种情况

目录 情况一:sort内存溢出,考虑增加服务器的排序缓冲区(sort_buffer_size)大小情况二:SQL语句问题 情况一:sort内存溢出,考虑增加服务器的排序缓冲区(sort_buffer_size)大小 1.查看缓冲
2023-08-18

编程热搜

目录