將.sql文件導(dǎo)入到MySQL數(shù)據(jù)庫具體步驟
導(dǎo)入 SQL 文件到 MySQL 數(shù)據(jù)庫是一個常見的任務(wù),本文將介紹如何執(zhí)行該操作。我們將逐步講解具體的步驟,幫助您完成這個過程。
步驟 1: 打開命令提示符或終端
首先,在您的計算機(jī)上打開命令提示符或終端窗口。這將是執(zhí)行導(dǎo)入操作的地方。
步驟 2: 確保 MySQL 命令行客戶端已安裝
在執(zhí)行導(dǎo)入操作之前,請確保您的計算機(jī)已安裝并且可以從命令提示符或終端訪問 MySQL 命令行客戶端。如果沒有安裝,您需要先安裝它或者調(diào)整系統(tǒng)的 PATH 環(huán)境變量。
步驟 3: 導(dǎo)航到 SQL 文件所在的目錄
使用 cd
命令(更改目錄)導(dǎo)航到存儲 SQL 文件的目錄。例如,如果您的 SQL 文件位于桌面上,可以使用以下命令:
cd Desktop
步驟 4: 導(dǎo)入 SQL 文件到 MySQL 數(shù)據(jù)庫
進(jìn)入到存儲 SQL 文件的目錄后,您可以使用以下命令將 SQL 文件導(dǎo)入到 MySQL 數(shù)據(jù)庫:
mysql -u 用戶名 -p 數(shù)據(jù)庫名 < 文件名.sql
請將命令中的 用戶名 替換為您的 MySQL 用戶名,數(shù)據(jù)庫名 替換為目標(biāo)數(shù)據(jù)庫的名稱,文件名.sql 替換為您的 SQL 文件的名稱。如果 SQL 文件位于不同的目錄中,請確保在文件名之前包括適當(dāng)?shù)奈募窂健?/p>
步驟 5: 輸入 MySQL 密碼
執(zhí)行上述命令后,系統(tǒng)會提示您輸入 MySQL 密碼。輸入與提供的用戶名相對應(yīng)的密碼,并按 Enter 鍵。
步驟 6: 等待導(dǎo)入完成
MySQL 將讀取并執(zhí)行 SQL 文件中的內(nèi)容,并將其導(dǎo)入到指定的數(shù)據(jù)庫中。根據(jù) SQL 文件的大小和查詢的復(fù)雜性,這個過程可能需要一些時間。待導(dǎo)入過程完成后,您將看到命令提示符或終端窗口返回。
到此,您已經(jīng)成功將 SQL 文件導(dǎo)入到 MySQL 數(shù)據(jù)庫中。您可以使用 MySQL 客戶端訪問數(shù)據(jù)庫,并執(zhí)行相應(yīng)的查詢來驗證導(dǎo)入的數(shù)據(jù)。
希望本文能夠幫助您順利地完成將 .sql 文件導(dǎo)入到 MySQL 數(shù)據(jù)庫的操作。
附:MySQL導(dǎo)入多個.sql文件高效方法
MySQL有多種方法導(dǎo)入多個.sql文件(里面是sql語句),常用的有兩個命令:mysql
和source
。
但是這兩個命令的導(dǎo)入效率差別很大,具體請看最后的比較。
(還有sqlimport和LOAD DATA INFILE等導(dǎo)入方法,不過它們主要用于導(dǎo)入.csv
或.xml
文件數(shù)據(jù),不是.sql
文件)
假設(shè)我們有一個 users.sql 大文件,為方便我們將其拆分成:user1.sql、user2.sql、user3.sql 三個獨立的小sql文件。
1 mysql命令導(dǎo)入
mysql命令導(dǎo)入多個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)入多個sql文件需要先創(chuàng)建一個額外的文件,名字隨意,這里我們?nèi)。?strong>all.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級以上文件,如果光這樣導(dǎo)入,速度是極其緩慢的,
根據(jù)MySQL官方建議,我們有幾個措施可以極大提高導(dǎo)入的速度,如下:
- 對于MyISAM,調(diào)整系統(tǒng)參數(shù):bulk_insert_buffer_size(至少單個文件大小的2倍以上)
- 對于InnoDB,調(diào)整系統(tǒng)參數(shù):innodb_log_buffer_size(至少單個文件大小的2倍以上,導(dǎo)入完成后可以改回默認(rèn)的8M,注意不是innodb_buffer_pool_size。)
- 除主鍵外,刪除其他索引,導(dǎo)入完成后重建索引。
- 關(guān)閉自動提交:
autocommit=0
。(請勿用set global autocommit=1;
命令來關(guān)閉,否則整個MySQL系統(tǒng)都會停止自動commit
,innodb log buffer很快就會爆滿,5和6項也請僅在會話中有效,正確做法請往下看) - 關(guān)閉唯一索引檢查:
unique_checks=0
。(關(guān)閉了這一項會影響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:
[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條寫在.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
按照以上幾個步驟調(diào)整后,插入速度必會有大幅度的提高。
總結(jié)
到此這篇關(guān)于將.sql文件導(dǎo)入到MySQL數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān).sql文件導(dǎo)入MySQL數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySql采用GROUP_CONCAT合并多條數(shù)據(jù)顯示的方法
這篇文章主要介紹了MySql采用GROUP_CONCAT合并多條數(shù)據(jù)顯示的方法,是MySQL數(shù)據(jù)庫程序設(shè)計中常見的實用技巧,需要的朋友可以參考下2014-10-10一臺電腦(windows系統(tǒng))安裝兩個版本MYSQL方法步驟
由于新舊項目數(shù)據(jù)庫版本差距太大,編碼格式不同,引擎也不同,所以只好裝兩個數(shù)據(jù)庫,這篇文章主要給大家介紹了關(guān)于一臺電腦(windows系統(tǒng))安裝兩個版本MYSQL的方法步驟,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03MySQL百萬級數(shù)據(jù)大分頁查詢優(yōu)化的實現(xiàn)
在數(shù)據(jù)庫開發(fā)過程中我們經(jīng)常會使用分頁,但是如果是百萬級數(shù)據(jù)呢,本文就詳細(xì)的介紹一下MySQL百萬級數(shù)據(jù)大分頁查詢優(yōu)化的實現(xiàn),感興趣的可以了解一下2022-01-01Ubuntu查看修改mysql的登錄名和密碼、安裝phpmyadmin
這篇文章主要介紹了Ubuntu查看修改mysql的登錄名和密碼、安裝phpmyadmin,本文分步驟給大家講解的非常詳細(xì),需要的朋友可以參考下2019-11-11