mysql大批量删除(修改)The total number of locks exceeds the lock table size 错误的解决办法

一、问题描述

开发中对一张大表进行批量的更新或者删除的时候 会报以下错误:

The total number of locks exceeds the lock table size

从字面上理解,就是当前操作锁住的总行数已经超过设置的锁表的大小。

二、解决办法

解决方案一:分批进行更新或者删除

如给delete 语句后面加上limit ,一次 1w条

delete from user where name like '%zs%' limit 10000;

解决方案二:调整mysql的innodb_buffer_pool_size 参数

innodb_buffer_pool_size 默认大小是128m(mysql8.0)

查看当前mysql的innodb_buffer_pool_size 大小
SHOW VARIABLES LIKE "%innodb_buffer_pool_size%";

临时设置 innodb_buffer_pool_size 大小为2g,重启mysql 以后失效
set global innodb_buffer_pool_size = 2147483648

永久生效需要改动my.cnf 配置文件,在配置文件中增加如下配置:

innodb_buffer_pool_size = 2G

然后重启mysql服务。
拓展:
innodb_buffer_pool_size(缓冲池大小)生产环境 mysql专用服务器 建议设置成服务器总内存的 70%到80%之间
innodb_buffer_pool_chunk_size(定义InnoDB缓冲池大小调整操作的块大小)
innodb_buffer_pool_instances(InnoDB 缓冲池划分为的区域数)
innodb_buffer_pool_size 必须是 innodb_buffer_pool_chunk_size 乘以 innodb_buffer_pool_instances 的倍数。

三、参考文章

  1. MySQL调优之innodb_buffer_pool_size大小设置
  2. MySQL优化:innodb_buffer_pool_instances与innodb_buffer_pool_size参数分析
  3. mysql8.0 官方文档
  4. Mysql解决The total number of locks exceeds the lock table size错误
  5. MYSQL解决 The total number of locks exceeds the lock table size 问题
  6. mysql底层解析——缓存,Innodb_buffer_pool,包括连接、解析、缓存、引擎、存储等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

T-OPEN

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值