1.找到mysql安装目录bin,用cmd打开,如果cmd能直接执行mysql命名最好。
2.导入数据命令
#windows执行导入,-p后面的密码直接写,不能有引号和空格 <前后也不能有空格,windows很不友好
mysql -u root -p123456 test<C:\Users\htzz\Desktop\test\test.sql
#linux执行导入,参数后面都挨着,有时不挨着会报错,很奇怪,也可能是我写法有问题吧
mysql -uroot -p'123456' test< /data/test.sql
3.直接导入时,如果有中文会出现1366编码错误问题(数据库编码集时utf8,一般cmd编码是gbk,导入编码集不一致就会报错),查询了很多网上的解决方案,都是查询show variables like '%character%'后改编码集,我本地试了很多种还是报错。现在普遍用的都是utf8编码,我不可能将整个数据库改成gbk编码,然后发现cmd直接执行chcp 65001 即可改变编码集(如下图),网上说win7/8/10均可用,该方式为最优解。
ERROR 1366 (HY000) at line 133: Incorrect string value: '\x80\xE5\xA7\x8B' for c
olumn 'ACT_NAME_' at row 1
4.导入后通过window的资源监控器发现,mysql.exe的磁盘读写速度最开也就100-200kd/s,太慢了,我一个g的sql文件得导入到什么时候,这个比navicat导入还慢(大概需要两个小时吧),mysql优化如下参数,速度立即提升。
#innodb_flush_log_at_trx_commit参数设置,默认值为1,先修改为2,导入完成后再改成1.该模式下,MySQL会每秒执行一次 flush(刷到磁盘)操作
set global innodb_flush_log_at_trx_commit = 2;
#global sync_binlog默认值为1,修改为2000,导入完成后再改成1. 当 sync_binlog =N (N>0) ,MySQL 在每写N次二进制日志binary log时,会使用fdatasync()函数将它的写二进制日志binary log同步到磁盘中去
set global sync_binlog = 2000;
#如果开启了binlog,导入时先关闭后开启
set sql_log_bin=0;
5.如上修改后,速度直接能到1-5m/s了,速度快了不少。
总结,通过linux上脚本执行情况看,linux执行mysqldump导出1g左右的数据一般4-20min中左右,linux上导入数据在不修改如上参数的情况下最慢也就十几分钟,完全可以接受不用修改参数影响其他数据库。