网络营销电子商务研究中心

网络营销电子商务研究中心 (https://www.0058.net/index.php)
-   MySQL (https://www.0058.net/forumdisplay.php?f=76)
-   -   Mysql导入大容量SQL文件数据问题 (https://www.0058.net/showthread.php?t=5792)

Fairbank 2016-07-04 06:26 AM

Mysql导入大容量SQL文件数据问题
 
mysql在通过导入sql文件可能会出现下面二个问题:

1.如果sql文件过大,会出现"MySQL server has gone away"问题;

2.如果sql文件数据有中文,会出现乱码



解决问题:

问题1:出现MySQL server has gone away"问题,是因为mysql默认的"max_allowed_packet"变量值过小.

查看目前配置

show VARIABLES like '%max_allowed_packet%';

显示的结果为:



+--------------------+---------+

| Variable_name | Value |

+--------------------+---------+

| max_allowed_packet | 1048576 |

+--------------------+---------+

说明目前的配置是:1048576/1024/1024 = 1M

-------------

修改max_allowed_packet值:

方法1: SET GLOBAL max_allowed_packet = 500*1024*1024;(经测试无效)

方法2: 直接修改配置文件,重启mysql

windows中修改my.ini文件,在linux中修改my.cnf文件.

重启mysql后,在查看修改后的max_allowed_packet值

问题2:登录时指定字符集编码

mysql -uroot -P3308 -p123456 - -default-character-set=utf8 (-P是指指定端口号)
-------------
最后通过source命令 即可成功导入:

source E:ydj\test.sql


All times are GMT +8. The time now is 04:07 AM.

Powered by vBulletin Version 3.8.7
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.