溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在MySQL中高效導(dǎo)入多個(gè).sql文件

發(fā)布時(shí)間:2021-05-10 16:43:27 來源:億速云 閱讀:353 作者:Leah 欄目:MySQL數(shù)據(jù)庫

本篇文章給大家分享的是有關(guān)怎么在MySQL中高效導(dǎo)入多個(gè).sql文件,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

1、mysql命令導(dǎo)入

mysql命令導(dǎo)入多個(gè)sql文件方法:

$ for SQL in *.sql; do mysql -uroot -p"123456" mydb < $SQL; done

2、source命令導(dǎo)入

source命令需要首先進(jìn)入MySQL命令行:

$ mysql -uroot -p"123456"

導(dǎo)入多個(gè)sql文件需要先創(chuàng)建一個(gè)額外的文件,名字隨意,這里我們?nèi)。篴ll.sql,內(nèi)容:

source user1.sql
source user2.sql
source user3.sql

注意,這里每行一條,必須以source命令開頭。

然后用source命令執(zhí)行該文件:

mysql > use mydb;
mysql > source /home/gary/all.sql

3、如何提高導(dǎo)入速度?

對于百M(fèi)級(jí)以上文件,如果光這樣導(dǎo)入,速度是極其緩慢的,

根據(jù)MySQL官方建議,我們有幾個(gè)措施可以極大提高導(dǎo)入的速度,如下:

對于MyISAM,調(diào)整系統(tǒng)參數(shù):bulk_insert_buffer_size(至少單個(gè)文件大小的2倍以上)

對于InnoDB,調(diào)整系統(tǒng)參數(shù):innodb_log_buffer_size(至少單個(gè)文件大小的2倍以上,導(dǎo)入完成后可以改回默認(rèn)的8M,注意不是innodb_buffer_pool_size。)

除主鍵外,刪除其他索引,導(dǎo)入完成后重建索引。

關(guān)閉自動(dòng)提交:autocommit=0。(請勿用set global autocommit=1;命令來關(guān)閉,否則整個(gè)MySQL系統(tǒng)都會(huì)停止自動(dòng)commit,innodb log buffer很快就會(huì)爆滿,5和6項(xiàng)也請僅在會(huì)話中有效,正確做法請往下看)

關(guān)閉唯一索引檢查:unique_checks=0。(關(guān)閉了這一項(xiàng)會(huì)影響on duplicate key update的效果)

關(guān)閉外鍵檢查:foreign_key_checks=0。

insert值寫在一條語句內(nèi),如:INSERT INTO yourtable VALUES (1,2), (5,5), ...;

有自增列的,設(shè)置: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中高效導(dǎo)入多個(gè).sql文件,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI