mysql 导入大量数据

150M的SQL文件,怎么导都出错,后来我用SQLyog导,直接显示内存不足,程序退出

后来我网上找资料,知道是MYSQL自身的限制,要改一些东西

我改了以下两个参数

max_allowed_packet
net_buffer_length

方法:

1) 方法1

可以编辑my.cnf来修改(windows下my.ini),在[mysqld]段或者mysql的server配置段进行修改。

max_allowed_packet = 20M

如果找不到my.cnf可以通过

mysql --help | grep my.cnf

去寻找my.cnf文件。

2) 方法2

(很妥协,很纠结的办法)

进入mysql server

在mysql 命令行中运行

set global max_allowed_packet = 2*1024*1024*10

然后关闭掉这此mysql server链接,再进入。

show VARIABLES like '%max_allowed_packet%';

查看下max_allowed_packet是否编辑成功

我用的是方法2,注意,要退出再次进入才可以看到是否修改成功。

我改的很大,然后用source *.sql很快的就导入了150M的数据库文件

纠结了几个小时,终于搞定了,回去睡觉!


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你在MySQL导入大量数据时,可能会遇到一些问题。一个常见的问题是导入速度很慢,导致耗时较长。这可能是由于默认的配置限制了导入数据的大小。在MySQL中,有一个配置项叫做`max_allowed_packet`,它控制了一次网络传输的最大数据包大小。默认情况下,这个值是4MB。 为了解决这个问题,你可以尝试修改`max_allowed_packet`的值,使其适应你正在导入数据量。你可以在`my.ini`配置文件中找到这个选项,并将其增加到一个更大的值,例如10MB或更大。修改完成后,记得重启MySQL服务,以使修改生效。 此外,如果你面临的是导入速度过慢的问题,你还可以考虑优化数据库的插入性能。一种常见的方法是使用批量插入,即将多条记录一起插入到数据库中,而不是每条记录都进行一次单独的插入操作。这样可以减少插入操作的次数,从而提高插入速度。 总结起来,当你在MySQL导入大量数据时,你可以尝试以下步骤来解决问题: 1. 修改`max_allowed_packet`配置项的值,使其适应你正在导入数据量。 2. 重启MySQL服务,使修改生效。 3. 考虑使用批量插入的方式来提高插入速度。 希望以上信息对你有帮助,如果还有其他问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [mysql快速导入大量数据问题](https://blog.csdn.net/weixin_28761455/article/details/113158471)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [MySQL导入数据量过大报错解决办法](https://blog.csdn.net/qq_42846807/article/details/114304995)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值