1. 程式人生 > >txt檔案匯入mysql

txt檔案匯入mysql

MySQL寫入資料通常用insert語句,如

  1. insert into person values(張三,20),(李四,21),(王五,70)…;   


但有時為了更快速地插入大批量資料或交換資料,需要從文字中匯入資料或匯出資料到文字。
一、 建立測試表,準備資料
首先建立一個用於測試的表示學生資訊的表,欄位有id、姓名、年齡、城市、薪水。Id和姓名不
能為空。

  1. create table person(  
  2. id int not null auto_increment,  
  3. name varchar(40) not null,  
  4. city varchar(20),  
  5. salary int
    ,  
  6. primary key(id)  
  7. )engine=innodb charset=gb2312;   

建立表截圖如下:
1
接著寫一個用於匯入的文字檔案:c:/data.txt。
張三 31 北京 3000
李四 25 杭州 4000
王五 45 /N 4500
小明 29 天津 /N
3
每一項之間用Tab鍵進行分隔,如果該欄位為NULL,則用/N表示。
二、 匯入資料
輸入命令,進行匯入。

  1. load data local infile “c:/data.txt”  
  2. into table person(name,age,city,salary);   

匯入資料截圖如下:
2
其中local表示本地。執行後,可以看到NULL資料也被正確地匯入。
三、 匯出資料

現在將這個表匯出為文字檔案:c:/data_out.txt。
  1. select name,age,city,salary  
  2. into outfile “c:/data_out.txt”  
  3. lines terminated by “/r/n”  
  4. 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可能不相同。