欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL高效導(dǎo)入多個(gè).sql文件方法詳解

 更新時(shí)間:2018年10月11日 15:16:06   投稿:wdc  
MySQL有多種方法導(dǎo)入多個(gè).sql文件,常用的有兩個(gè)命令:mysql和source,如何提高導(dǎo)入速度,在導(dǎo)入大的sql文件時(shí),建議使用mysql命令

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值寫(xiě)在一條語(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條寫(xiě)在.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自動(dòng)定時(shí)備份數(shù)據(jù)庫(kù)的最佳方法(windows服務(wù)器)

    mysql自動(dòng)定時(shí)備份數(shù)據(jù)庫(kù)的最佳方法(windows服務(wù)器)

    網(wǎng)上有很多關(guān)于window下Mysql自動(dòng)備份的方法,可是真的能用的也沒(méi)有幾個(gè),有些說(shuō)的還非常的復(fù)雜,難以操作,這里腳本之家小編為大家分享與整理了幾個(gè)軟件方便大家使用
    2016-11-11
  • Mysql導(dǎo)出數(shù)據(jù)的正確方法

    Mysql導(dǎo)出數(shù)據(jù)的正確方法

    想在Mysql命令行下導(dǎo)出數(shù)據(jù)庫(kù),但就是每天提示不那個(gè)錯(cuò)誤,后來(lái)才知道其實(shí)mysqldump不是mysql命令,因此不能在Mysql命令行下導(dǎo)出。
    2011-05-05
  • Mac下忘記mysql密碼重新設(shè)置密碼的圖文教程

    Mac下忘記mysql密碼重新設(shè)置密碼的圖文教程

    這篇文章主要介紹了Mac下忘記mysql密碼重新設(shè)置密碼的教程,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-12-12
  • MYSQL必知必會(huì)讀書(shū)筆記 第一章(基礎(chǔ))

    MYSQL必知必會(huì)讀書(shū)筆記 第一章(基礎(chǔ))

    數(shù)據(jù)庫(kù)(database)是一個(gè)以某種有組織的方式存儲(chǔ)的數(shù)據(jù)集合。本文是小編日常收集整理些有關(guān)mysql的知識(shí),非常具有參考價(jià)值,感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • MySQL Range Columns分區(qū)的使用

    MySQL Range Columns分區(qū)的使用

    Range Columns分區(qū)是一種靈活的分區(qū)策略,允許基于列值的范圍將數(shù)據(jù)分到不同的分區(qū),本文主要介紹了MySQL Range Columns分區(qū)的使用,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • mysql 8.0.15 安裝配置方法圖文教程(Windows10 X64)

    mysql 8.0.15 安裝配置方法圖文教程(Windows10 X64)

    這篇文章主要為大家詳細(xì)介紹了Windows10 X64 mysql 8.0.15 安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • CentOS7 通過(guò)YUM安裝MySQL5.7的步驟詳解

    CentOS7 通過(guò)YUM安裝MySQL5.7的步驟詳解

    這篇文章主要介紹了CentOS7 通過(guò)YUM安裝MySQL5.7的步驟詳解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • Linux下JDK安裝教程

    Linux下JDK安裝教程

    這篇文章主要介紹了Linux下JDK安裝教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-07-07
  • MySQL大小寫(xiě)敏感的注意事項(xiàng)

    MySQL大小寫(xiě)敏感的注意事項(xiàng)

    MySQL 在 Windows 下不區(qū)分大小寫(xiě),但在 Linux 下默認(rèn)是區(qū)分大小寫(xiě)。如果你稍加不注意就會(huì)出現(xiàn)在本機(jī)開(kāi)發(fā)的程序運(yùn)行一切正常,發(fā)布到服務(wù)器行就出現(xiàn)表名找不到的問(wèn)題,一頭霧水。
    2021-05-05
  • MySQL 關(guān)于表復(fù)制 insert into 語(yǔ)法的詳細(xì)介紹

    MySQL 關(guān)于表復(fù)制 insert into 語(yǔ)法的詳細(xì)介紹

    本篇文章是對(duì)MySQL中關(guān)于表復(fù)制insert into語(yǔ)法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-07-07

最新評(píng)論