MySQL 报错:The total number of locks exceeds the lock table size

在这里插入图片描述
本地MYSQL插入630W+数据失败报错

(1206, 'The total number of locks exceeds the lock table size')

数据量过大就容易造成以上报错,因为mysql默认缓存大小为8M,可以查看一下自己的MySQL缓存大小
进入mysql客户端输入命令

show variables like "%_buffer%";  

在这里插入图片描述
只有8388608 B,换算成M即除以两个1024,就是8M,

我们直接给它改成1G,即1*1024*1024*1024=1073741824 B
执行

SET GLOBAL innodb_buffer_pool_size=1073741824;

再次执行show variables like "%_buffer%"; 这个操作

在这里插入图片描述
看到当前缓存内存改变了,继续之前的插入操作试试

在这里插入图片描述

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注