MySQL有多种方法导入多个.sql文件(里面是sql语句),常用的有两个命令:mysql和source。
但是这两个命令的导入效率差别很大,具体请看最后的比较。
(还有sqlimport和LOAD DATA INFILE等导入方法,不过它们主要用于导入.csv或.xml文件数据,不是.sql文件)
假设我们有一个 users.sql 大文件,为方便我们将其拆分成:user1.sql、user2.sql、user3.sql 三个独立的小sql文件。
1、mysql命令导入
mysql命令导入多个sql文件方法:
$ for SQL in *.sql; do mysql -uroot -p"123456" mydb < $SQL; done
2、source命令导入
source命令需要首先进入MySQL命令行:
$ mysql -uroot -p"123456"
导入多个sql文件需要先创建一个额外的文件,名字随意,这里我们取:all.sql,内容:
source user1.sql
source user2.sql
source user3.sql
注意,这里每行一条,必须以source命令开头。
然后用source命令执行该文件:
mysql > use mydb;
mysql > source /home/gary/all.sql
3、如何提高导入速度?
对于百M级以上文件,如果光这样导入,速度是极其缓慢的,
根据MySQL官方建议,我们有几个措施可以极大提高导入的速度,如下:
对于MyISAM,调整系统参数:bulk_insert_buffer_size(至少单个文件大小的2倍以上)
对于InnoDB,调整系统参数:innodb_log_buffer_size(至少单个文件大小的2倍以上,导入完成后可以改回默认的8M,注意不是i

本文介绍了MySQL导入多个.sql文件的两种方法:mysql命令和source命令,并提供了提高导入速度的优化措施,包括调整系统参数、删除及重建索引等。在大文件导入时,推荐使用mysql命令以提高效率。
最低0.47元/天 解锁文章
2341

被折叠的 条评论
为什么被折叠?



