MySQL 文本文件的導(dǎo)入導(dǎo)出數(shù)據(jù)的方法

但有時(shí)為了更快速地插入大批量數(shù)據(jù)或交換數(shù)據(jù),需要從文本中導(dǎo)入數(shù)據(jù)或?qū)С鰯?shù)據(jù)到文本。下面的具體的方法大家可以參考下。多測(cè)試。

MySQL寫入數(shù)據(jù)通常用insert語句,如
代碼如下:
insert into person values(張三,20),(李四,21),(王五,70)…;

但有時(shí)為了更快速地插入大批量數(shù)據(jù)或交換數(shù)據(jù),需要從文本中導(dǎo)入數(shù)據(jù)或?qū)С鰯?shù)據(jù)到文本。
一、 建立測(cè)試表,準(zhǔn)備數(shù)據(jù)
首先建立一個(gè)用于測(cè)試的表示學(xué)生信息的表,字段有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;

創(chuàng)建表截圖如下:

接著寫一個(gè)用于導(dǎo)入的文本文件:c:data.txt。
張三 31 北京 3000
李四 25 杭州 4000
王五 45 N 4500
小明 29 天津 N

每一項(xiàng)之間用Tab鍵進(jìn)行分隔,如果該字段為NULL,則用N表示。
二、 導(dǎo)入數(shù)據(jù)
輸入命令,進(jìn)行導(dǎo)入。
load data local infile “c:/data.txt”
into table person(name,age,city,salary);
導(dǎo)入數(shù)據(jù)截圖如下:

其中l(wèi)ocal表示本地。執(zhí)行后,可以看到NULL數(shù)據(jù)也被正確地導(dǎo)入。
三、 導(dǎo)出數(shù)據(jù)

現(xiàn)在將這個(gè)表導(dǎo)出為文本文件:c:data_out.txt。
代碼如下:
select name,age,city,salary
into outfile “c:/data_out.txt”
lines terminated by “rn”
from person;

導(dǎo)出數(shù)據(jù)截圖如下:

其中l(wèi)ines terminated by “rn”表示每一行(即每一條記錄)用rn分隔,rn是window系
統(tǒng)的換行符。導(dǎo)出的data_out.txt與data.txt的內(nèi)容完全一樣。
四、 運(yùn)行環(huán)境

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

字段之間的分隔和記錄(行)之間的分隔默認(rèn)是t(即Tab)和n。但可以改變,如:
FIELDS TERMINATED BY ‘,’ –字段用,進(jìn)行分隔
LINES TERMINATED BY ‘;’ –記錄用; 進(jìn)行分隔
另外要注意其它操作系統(tǒng)的換行符與windows可能不相同。

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊8 分享