mysql大量删除 索引失效_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** 的倍数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值