婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL高效導入多個.sql文件方法詳解

MySQL高效導入多個.sql文件方法詳解

熱門標簽:高德地圖標注模式 湘潭電銷機器人咨詢電話 400電話辦理都選易號網 高德地圖標注中心個人注冊 寶應電信400電話辦理費用 外呼系統防封號違法嗎 電銷機器人針對的 如何在高德地圖標注新地址 外呼系統服務

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,注意不是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

按照以上幾個步驟調整后,插入速度必會有大幅度的提高。

4、mysql和source效率比較

在sql文件較小的情況下,source速度比mysql高,

在實際測試導入時,5個合計25M的sql文件,mysql命令的速度比source要快2秒(我自己的測試,不代表普遍的結果),

可以粗略得出,在導入大的sql文件時,建議使用mysql命令。

以上既是MySQL高效導入多個.sql文件的方法,希望能幫助到大家

您可能感興趣的文章:
  • MySQL從命令行導入SQL腳本時出現中文亂碼的解決方法
  • MySQL導入sql腳本錯誤:2006 解決方法
  • mysql導入sql文件報錯 ERROR 2013 2006 2002
  • mysql導入sql文件命令和mysql遠程登陸使用詳解
  • 在linux中導入sql文件的方法分享(使用命令行轉移mysql數據庫)
  • 解析MYSQL 數據庫導入SQL 文件出現亂碼的問題
  • Mysql命令行導入sql數據的代碼
  • Mysql命令行導入sql數據

標簽:黃山 宿遷 黔南 馬鞍山 佛山 賀州 蘭州 南充

巨人網絡通訊聲明:本文標題《MySQL高效導入多個.sql文件方法詳解》,本文關鍵詞  MySQL,高效,導入,多個,.sql,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL高效導入多個.sql文件方法詳解》相關的同類信息!
  • 本頁收集關于MySQL高效導入多個.sql文件方法詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 襄汾县| 深水埗区| 方正县| 嵊州市| 三亚市| 英吉沙县| 阿尔山市| 泰安市| 象山县| 张家川| 阜南县| 渭南市| 扎兰屯市| 成武县| 古浪县| 香格里拉县| 嘉黎县| 民乐县| 吴川市| 孟津县| 庆元县| 丹东市| 双柏县| 南乐县| 内江市| 赣州市| 冕宁县| 汾阳市| 宜州市| 浪卡子县| 永修县| 夏邑县| 蓬溪县| 拉萨市| 且末县| 凯里市| 蒙山县| 闻喜县| 怀安县| 鄂州市| 寻乌县|