您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關怎么在MySQL中高效導入多個.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,注意不是innodb_buffer_pool_size。)
除主鍵外,刪除其他索引,導入完成后重建索引。
關閉自動提交:autocommit=0。(請勿用set global autocommit=1;命令來關閉,否則整個MySQL系統都會停止自動commit,innodb log buffer很快就會爆滿,5和6項也請僅在會話中有效,正確做法請往下看)
關閉唯一索引檢查:unique_checks=0。(關閉了這一項會影響on duplicate key update的效果)
關閉外鍵檢查:foreign_key_checks=0。
insert值寫在一條語句內,如:INSERT INTO yourtable VALUES (1,2), (5,5), ...;
有自增列的,設置:innodb_autoinc_lock_mode的值為2,
其中,第1-2、8條在修改my.cnf文件,然后重啟MySQL:
bulk_insert_buffer_size=2G; innodb_log_buffer_size=2G; innodb_autoinc_lock_mode=2;
第3條用到的命令:
#刪除索引 DROP INDEX index_name ON talbe_name ALTER TABLE table_name DROP INDEX index_name ALTER TABLE table_name DROP PRIMARY KEY # 添加索引 ALTER TABLE table_name ADD INDEX index_name (column_list) ALTER TABLE table_name ADD UNIQUE (column_list) ALTER TABLE table_name ADD PRIMARY KEY (column_list)
第4-6條寫在.sql中,批量bash腳本如下:
for SQL in *.sql; do echo $SQL; sed -i '1i\SET autocommit=0;\nSET unique_checks=0;\nSET foreign_key_checks=0;' $SQL sed -i '$a\COMMIT;\nSET autocommit=1;\nSET unique_checks=1;\nSET foreign_key_checks=1;' $SQL done
以上就是怎么在MySQL中高效導入多個.sql文件,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。