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

將.sql文件導(dǎo)入到MySQL數(shù)據(jù)庫(kù)具體步驟

 更新時(shí)間:2023年10月25日 10:15:47   作者:Bo1Liu2  
MySQL有多種方法導(dǎo)入多個(gè).sql文件,下面這篇文章主要介紹了將.sql文件導(dǎo)入到MySQL數(shù)據(jù)庫(kù)的具體步驟,文中將實(shí)現(xiàn)步驟介紹的非常詳細(xì),需要的朋友可以參考下

導(dǎo)入 SQL 文件到 MySQL 數(shù)據(jù)庫(kù)是一個(gè)常見(jiàn)的任務(wù),本文將介紹如何執(zhí)行該操作。我們將逐步講解具體的步驟,幫助您完成這個(gè)過(guò)程。

步驟 1: 打開(kāi)命令提示符或終端

首先,在您的計(jì)算機(jī)上打開(kāi)命令提示符或終端窗口。這將是執(zhí)行導(dǎo)入操作的地方。

步驟 2: 確保 MySQL 命令行客戶端已安裝

在執(zhí)行導(dǎo)入操作之前,請(qǐng)確保您的計(jì)算機(jī)已安裝并且可以從命令提示符或終端訪問(wèn) MySQL 命令行客戶端。如果沒(méi)有安裝,您需要先安裝它或者調(diào)整系統(tǒng)的 PATH 環(huán)境變量。

步驟 3: 導(dǎo)航到 SQL 文件所在的目錄

使用 cd 命令(更改目錄)導(dǎo)航到存儲(chǔ) SQL 文件的目錄。例如,如果您的 SQL 文件位于桌面上,可以使用以下命令:

cd Desktop

步驟 4: 導(dǎo)入 SQL 文件到 MySQL 數(shù)據(jù)庫(kù)

進(jìn)入到存儲(chǔ) SQL 文件的目錄后,您可以使用以下命令將 SQL 文件導(dǎo)入到 MySQL 數(shù)據(jù)庫(kù):

mysql -u 用戶名 -p 數(shù)據(jù)庫(kù)名 < 文件名.sql

請(qǐng)將命令中的 用戶名 替換為您的 MySQL 用戶名,數(shù)據(jù)庫(kù)名 替換為目標(biāo)數(shù)據(jù)庫(kù)的名稱,文件名.sql 替換為您的 SQL 文件的名稱。如果 SQL 文件位于不同的目錄中,請(qǐng)確保在文件名之前包括適當(dāng)?shù)奈募窂健?/p>

步驟 5: 輸入 MySQL 密碼

執(zhí)行上述命令后,系統(tǒng)會(huì)提示您輸入 MySQL 密碼。輸入與提供的用戶名相對(duì)應(yīng)的密碼,并按 Enter 鍵。

步驟 6: 等待導(dǎo)入完成

MySQL 將讀取并執(zhí)行 SQL 文件中的內(nèi)容,并將其導(dǎo)入到指定的數(shù)據(jù)庫(kù)中。根據(jù) SQL 文件的大小和查詢的復(fù)雜性,這個(gè)過(guò)程可能需要一些時(shí)間。待導(dǎo)入過(guò)程完成后,您將看到命令提示符或終端窗口返回。

到此,您已經(jīng)成功將 SQL 文件導(dǎo)入到 MySQL 數(shù)據(jù)庫(kù)中。您可以使用 MySQL 客戶端訪問(wèn)數(shù)據(jù)庫(kù),并執(zhí)行相應(yīng)的查詢來(lái)驗(yàn)證導(dǎo)入的數(shù)據(jù)。

希望本文能夠幫助您順利地完成將 .sql 文件導(dǎo)入到 MySQL 數(shù)據(jù)庫(kù)的操作。

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

MySQL有多種方法導(dǎo)入多個(gè).sql文件(里面是sql語(yǔ)句),常用的有兩個(gè)命令:mysqlsource。

但是這兩個(gè)命令的導(dǎo)入效率差別很大,具體請(qǐng)看最后的比較。

(還有sqlimportLOAD 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)。?strong>all.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:

[mysqld]
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ì)有大幅度的提高。

總結(jié)

到此這篇關(guān)于將.sql文件導(dǎo)入到MySQL數(shù)據(jù)庫(kù)的文章就介紹到這了,更多相關(guān).sql文件導(dǎo)入MySQL數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論