MySQL高效導(dǎo)入多個(gè).sql文件方法詳解
MySQL有多種方法導(dǎo)入多個(gè).sql文件(里面是sql語(yǔ)句),常用的有兩個(gè)命令:mysql和source。
但是這兩個(gè)命令的導(dǎo)入效率差別很大,具體請(qǐng)看最后的比較。
(還有sqlimport和LOAD DATA INFILE等導(dǎo)入方法,不過(guò)它們主要用于導(dǎo)入.csv或.xml文件數(shù)據(jù),不是.sql文件)
假設(shè)我們有一個(gè) users.sql 大文件,為方便我們將其拆分成:user1.sql、user2.sql、user3.sql 三個(gè)獨(dú)立的小sql文件。
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命令開(kāi)頭。
然后用source命令執(zhí)行該文件:
mysql > use mydb; mysql > source /home/gary/all.sql
3、如何提高導(dǎo)入速度?
對(duì)于百M(fèi)級(jí)以上文件,如果光這樣導(dǎo)入,速度是極其緩慢的,
根據(jù)MySQL官方建議,我們有幾個(gè)措施可以極大提高導(dǎo)入的速度,如下:
對(duì)于MyISAM,調(diào)整系統(tǒng)參數(shù):bulk_insert_buffer_size(至少單個(gè)文件大小的2倍以上)
對(duì)于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。(請(qǐng)勿用set global autocommit=1;命令來(lái)關(guān)閉,否則整個(gè)MySQL系統(tǒng)都會(huì)停止自動(dòng)commit,innodb log buffer很快就會(huì)爆滿,5和6項(xiàng)也請(qǐng)僅在會(huì)話中有效,正確做法請(qǐng)往下看)
關(guān)閉唯一索引檢查:unique_checks=0。(關(guān)閉了這一項(xiàng)會(huì)影響on duplicate key update的效果)
關(guān)閉外鍵檢查:foreign_key_checks=0。
insert值寫在一條語(yǔ)句內(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
按照以上幾個(gè)步驟調(diào)整后,插入速度必會(huì)有大幅度的提高。
4、mysql和source效率比較
在sql文件較小的情況下,source速度比mysql高,
在實(shí)際測(cè)試導(dǎo)入時(shí),5個(gè)合計(jì)25M的sql文件,mysql命令的速度比source要快2秒(我自己的測(cè)試,不代表普遍的結(jié)果),
可以粗略得出,在導(dǎo)入大的sql文件時(shí),建議使用mysql命令。
以上既是MySQL高效導(dǎo)入多個(gè).sql文件的方法,希望能幫助到大家
相關(guān)文章
MySQL之存儲(chǔ)過(guò)程按月創(chuàng)建表的方法步驟
這篇文章主要介紹了MySQL之存儲(chǔ)過(guò)程按月創(chuàng)建表的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09MySQL延遲問(wèn)題和數(shù)據(jù)刷盤策略流程分析
這篇文章主要介紹了MySQL延遲問(wèn)題和數(shù)據(jù)刷盤策略流程分析,本文要給大家提到了mysql復(fù)制流程,需要的朋友可以參考下2020-02-02MySQL數(shù)據(jù)入庫(kù)時(shí)特殊字符處理詳解
本文是對(duì)MySQL數(shù)據(jù)入庫(kù)時(shí)特殊字符的處理進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11MySQL流程函數(shù)常見(jiàn)用法實(shí)例分析
這篇文章主要介紹了MySQL流程函數(shù)常見(jiàn)用法,結(jié)合實(shí)例形式分析了mysql流程函數(shù)功能、常見(jiàn)使用方法與操作注意事項(xiàng),需要的朋友可以參考下2019-12-12mysql中insert?into...select語(yǔ)句優(yōu)化方式
這篇文章主要介紹了mysql中insert?into...select語(yǔ)句優(yōu)化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教<BR>2024-04-04MySQL安裝與配置:手工配置MySQL(windows環(huán)境)過(guò)程
這篇文章主要介紹了MySQL安裝與配置:手工配置MySQL(windows環(huán)境)過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12