txt文件導入mysql

MySQL寫入數據通常用insert語句,如

[c-sharp] view plaincopy
  1. insert into person values(張三,20),(李四,21),(王五,70)…;   


但有時爲了更快速地插入大批量數據或交換數據,需要從文本中導入數據或導出數據到文本。 
一、 建立測試表,準備數據 
首先建立一個用於測試的表示學生信息的表,字段有id、姓名、年齡、城市、薪水。Id和姓名不 
能爲空。


[c-sharp] view plaincopy
  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表示。 
二、 導入數據 
輸入命令,進行導入。 

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

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

現在將這個表導出爲文本文件:c:/data_out.txt。

[c-sharp] view plaincopy
  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可能不相同。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章