mysql导入txt文件

文章来源: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-infile
make  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) "

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。