1. 程式人生 > >MySQL 文字檔案的匯入匯出資料的方法

MySQL 文字檔案的匯入匯出資料的方法

MySQL寫入資料通常用insert語句,如 
複製程式碼程式碼如下:
insert into person values(張三,20),(李四,21),(王五,70)…; 

但有時為了更快速地插入大批量資料或交換資料,需要從文字中匯入資料或匯出資料到文字。 
一、 建立測試表,準備資料
首先建立一個用於測試的表示學生資訊的表,欄位有id、姓名、年齡、城市、薪水。Id和姓名不 
能為空。 
複製程式碼程式碼如下:
create table person( 
id int not null auto_increment, 
name varchar(40) not null, 
city varchar(20), 
salary int, 
primary key(id) 
)engine=innodb charset=gb2312; 

建立表截圖如下: 

1
接著寫一個用於匯入的文字檔案:c:\data.txt。 
張三 31 北京 3000 
李四 25 杭州 4000 
王五 45 \N 4500 
小明 29 天津 \N 
3
每一項之間用Tab鍵進行分隔,如果該欄位為NULL,則用\N表示。 
二、 匯入資料
輸入命令,進行匯入。 
load data local infile “c:/data.txt” 
into table person(name,age,city,salary); 
匯入資料截圖如下: 
2
其中local表示本地。執行後,可以看到NULL資料也被正確地匯入。 
三、 匯出資料 

現在將這個表匯出為文字檔案:c:\data_out.txt。 
複製程式碼程式碼如下:
select name,age,city,salary 
into outfile “c:/data_out.txt” 
lines terminated by “\r\n” 
from person; 

匯出資料截圖如下: 

4
其中lines terminated by “\r\n”表示每一行(即每一條記錄)用\r\n分隔,\r\n是window系 
統的換行符。匯出的data_out.txt與data.txt的內容完全一樣。 
四、 執行環境

Windows vista home basic 
MySQL 5.1.34-community 
五、 注意

欄位之間的分隔和記錄(行)之間的分隔預設是\t(即Tab)和\n。但可以改變,如: 
FIELDS TERMINATED BY ',' --欄位用,進行分隔 
LINES TERMINATED BY ';' --記錄用; 進行分隔 
另外要注意其它作業系統的換行符與windows可能不相同。