用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字

baobao    -  云代码空间

——

将txt内容导入到mysql数据表中

2016-02-02|1203阅||

摘要:将txt内容导入到mysql数据表中

为了更快速地插入大批量数据或交换数据,需要从文本中导入数据或导出数据到文本。

一、 建立测试表,准备数据
首先建立一个用于测试的表示学生信息的表,字段有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可能不相同。
顶 0踩 0收藏
文章评论
    发表评论

    个人资料

    • 昵称: baobao
    • 等级: 中级程序员
    • 积分: 215
    • 代码: 3 个
    • 文章: 3 篇
    • 随想: 0 条
    • 访问: 0 次
    • 关注

    最新提问

      站长推荐