MySQL 表數(shù)據(jù)的導(dǎo)入導(dǎo)出操作示例
本文實(shí)例講述了MySQL 表數(shù)據(jù)的導(dǎo)入導(dǎo)出操作。分享給大家供大家參考,具體如下:
數(shù)據(jù)導(dǎo)出
1. 使用 SELECT ...INTO OUTFILE ...命令來導(dǎo)出數(shù)據(jù),具體語法如下。
mysql> SELECT * FROM tablename INTO OUTFILE 'target_file' [option];
其中 option 參數(shù)可以是以下選項(xiàng):
FIELDS TEMINATED BY 'string' (字符分?jǐn)喾?
FIELDS [OPTIONALLY] ENCLOSED BY 'CHAR' (字段引用符,如果加OPTIONAL選項(xiàng)則只用在char、varchar 和 text 等字符型字段上。默認(rèn)不使用引用符)
FIELDS EXCAPED BY 'CAHR' (轉(zhuǎn)移字符,默認(rèn)為'\')
LINES STARTING BY 'string' (每行前都加此字符串,默認(rèn)'')
LINES TERMINATED BY 'string' (行結(jié)束符,默認(rèn)為'\n')
其中char表示此符號只能是單個字符,string 表示可以是字符串。
Example: 導(dǎo)出test表的所有數(shù)據(jù) mysql> select * from test into outfile '/path/files.txt'
2. 用mysqldump 導(dǎo)出數(shù)據(jù)為文本
mysqldump -u username -T target_dir dbname tablename [option] 其中option 參數(shù)可以是以下選項(xiàng): --fields-terminated-by=name(字段分隔符); --fields-enclosed-by=name(字段引用符); --fields-optionally-enclosed-by=name(字段引用符,只用在 char、varchar 和 text 等字符 型字段上); --fields-escaped-by=name(轉(zhuǎn)義字符); --lines-terminated-by=name(記錄結(jié)束符)。 Example: 導(dǎo)出test數(shù)據(jù)庫中的custom表的所有數(shù)據(jù) mysqldump -uroot -T /tmp test custom
除了生成數(shù)據(jù)文件 custom.txt 之外,還生成一個 custom.sql 文件,里面記錄了 custom 表的創(chuàng)建腳本。
數(shù)據(jù)導(dǎo)入
只討論用 SELECT... INTO OUTFILE 或者 mysqldump 導(dǎo)出的純數(shù)據(jù)文本的導(dǎo)入方法。
1. 使用"LOAD DATA INFILE..."
mysql > LOAD DATA [LOCAL] INFILE 'filename' into TABLE tablename [option] option 可以是以下選項(xiàng): ¡ FIELDS TERMINATED BY 'string'(字段分隔符,默認(rèn)為制表符'\t'); ¡ FIELDS [OPTIONALLY] ENCLOSED BY 'char'(字段引用符,如果加 OPTIONALLY 選項(xiàng)則只用 在 char、varchar 和 text 等字符型字段上。默認(rèn)不使用引用符); ESCAPED BY 'char'(轉(zhuǎn)義字符,默認(rèn)為'\'); STARTING BY 'string'(每行前都加此字符串,默認(rèn)''); TERMINATED BY 'string'(行結(jié)束符,默認(rèn)為'\n'); ¡ FIELDS ¡ LINES ¡ LINES ¡ IGNORE number LINES(忽略輸入文件中的前 n 行數(shù)據(jù)); ¡ (col_name_or_user_var,...) (按照列出的字段順序和字段數(shù)量加載數(shù)據(jù)); ¡ SET col_name = expr,... 將列做一定的數(shù)值轉(zhuǎn)換后再加載。 其中 char 表示此符號只能是單個字符,string 表示可以是字符串。 FILELD 和 LINES 和前面 SELECT ...INTO OUTFILE...的含義完全相同,不同的是多了幾個不同的選 項(xiàng),下面的例子將文件“/tmp/emp.txt”中的數(shù)據(jù)加載到表 emp 中: mysql > load data infile '/tmp/emp.txt' into table emp 如果不希望加載文件中的前兩行,可以如下操作: mysql> load data infile '/tmp/emp.txt' into table emp fields ignore 2 lines;
指定導(dǎo)入的列:
mysql > load data infile '/tmp/emp.txt' into table emp ignore 2 lines (id,content,name);
2. 用mysqlimport 來實(shí)現(xiàn),具體命令如下:
shell > mysqlimport -u root -p*** [--LOCAL] dbname order_tab.txt [option] Example: 導(dǎo)入數(shù)據(jù)到order表 shell > mysqlimport -uroot test /tmp/emp.txt
注意:如果導(dǎo)入和導(dǎo)出是跨平臺操作的(Windows 和 Linux),那么要注意設(shè)置參數(shù) line-terminated-by , Windows 上 設(shè) 置 為 line-terminated-by='\r\n' , Linux 上 設(shè) 置 為 line-terminated-by='\n'。
清空表數(shù)據(jù)
delete from 表名;
truncate table 表名;
不帶where參數(shù)的delete語句可以刪除mysql表中所有內(nèi)容,使用truncate table也可以清空mysql表中所有內(nèi)容。
效率上truncate比delete快,但truncate刪除后不記錄mysql日志,不可以恢復(fù)數(shù)據(jù)。
delete的效果有點(diǎn)像將mysql表中所有記錄一條一條刪除到刪完,
而truncate相當(dāng)于保留mysql表的結(jié)構(gòu),重新創(chuàng)建了這個表,所有的狀態(tài)都相當(dāng)于新表。
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計(jì)有所幫助。
- mysql數(shù)據(jù)庫如何導(dǎo)入導(dǎo)出sql文件
- Mysql數(shù)據(jù)庫的導(dǎo)入導(dǎo)出方式(各種情況)
- MySQL數(shù)據(jù)備份、還原、數(shù)據(jù)庫遷移以及表的導(dǎo)出和導(dǎo)入
- MySQL 億級數(shù)據(jù)導(dǎo)入導(dǎo)出及遷移筆記
- HeidiSQL工具導(dǎo)出導(dǎo)入MySQL數(shù)據(jù)
- 淺析MySQL數(shù)據(jù)的導(dǎo)出與導(dǎo)入知識點(diǎn)
- Python之csv文件從MySQL數(shù)據(jù)庫導(dǎo)入導(dǎo)出的方法
- MySQL命令行導(dǎo)出導(dǎo)入數(shù)據(jù)庫實(shí)例詳解
- MySQL 導(dǎo)出和導(dǎo)入數(shù)據(jù)的幾種實(shí)現(xiàn)方式
相關(guān)文章
mysql 5.7.5 m15 winx64.zip安裝教程
這篇文章主要為大家詳細(xì)介紹了mysql 5.7.5 m15 winx64.zip安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06MySQL?8.0新特性之集合操作符INTERSECT和EXCEPT
MySQL8.0.31版本開始支持了INTERSECT(交集)和EXCEPT(差集)運(yùn)算,INTERSECT返回兩個結(jié)果集中都包含的行,EXCEPT返回左側(cè)結(jié)果集存在,右側(cè)不存在的行,這篇文章主要給大家介紹了關(guān)于MySQL?8.0新特性之集合操作符INTERSECT和EXCEPT的相關(guān)資料,需要的朋友可以參考下2022-10-10MySQL DISTINCT 的基本實(shí)現(xiàn)原理詳解
這篇文章主要介紹了MySQL DISTINCT 的基本實(shí)現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07mysql數(shù)據(jù)庫亂碼之保存越南文亂碼解決方法
做一個包含越南文的網(wǎng)站,用戶說在保存包含越南文的文章時,MSYQL亂碼了,看下面的解決方法2013-12-12MySQL數(shù)據(jù)庫InnoDB引擎下服務(wù)器斷電數(shù)據(jù)恢復(fù)方法
這篇文章主要介紹了MySQL數(shù)據(jù)庫InnoDB引擎下服務(wù)器斷電數(shù)據(jù)恢復(fù)方法,需要的朋友可以參考下2016-04-04MySQL分組查詢Group By實(shí)現(xiàn)原理詳解
在MySQL 中,GROUP BY 的實(shí)現(xiàn)同樣有多種(三種)方式,其中有兩種方式會利用現(xiàn)有的索引信息來完成 GROUP BY,另外一種為完全無法使用索引的場景下使用。下面我們分別針對這三種實(shí)現(xiàn)方式做一個分析2016-05-05