mysql匯入txt檔案

來源:互聯網
上載者:User

標籤:

文章來源:http://blog.csdn.net/piaolankeke/article/details/6272214

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;   

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

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


匯入資料如下: 
 
其中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;   


匯出資料如下: 
 
其中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可能不相同。

 

關於MYSQL LOAD DATA LOCAL INFILE支援問題 1.執行報錯:ERROR 1148 (42000): The used command is not allowed with this MySQL version解決方案: 先進入MYSQL檢查一下版本號碼:5.1或者以上的都支援。mysql> select version() 1.由於MYSQL編譯安裝時預設不允許執行這個命令。1)安裝時加上 --enable-local-infile 參數就可以了執行了。./configure --prefix=/usr/local/mysql --enable-local-infilemake  www.2cto.com  make install 2.可以在執行命中加上--local-infile=1 參數即可解決。如:/usr/local/mysql/bin/mysql -uroot -h192.168.0.2 -proot databaseName --local-infile=1 -e "LOAD DATA LOCAL INFILE ‘data.txt‘ into table test(name,sex) "

mysql匯入txt檔案(轉)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.