LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE '' [REPLACE | IGNORE] INTO TABLE [CHARACTER SET ] [{FIELDS | COLUMNS} [TERMINATED BY ''] [[OPTIONALLY] ENCLOSED BY ''] [ESCAPED BY ''] ] [LINES [STARTING BY ''] [TERMINATED BY ''] ] [IGNORE LINES] [(,...)] [SET = ,...]file_nametbl_namecharset_namestringcharcharstringstringnumbercol_name_or_user_varcol_nameexpr
MySQL写入数据一般用insert语句,如windows
[c-sharp] view plain copyapp
但有时为了更快速地插入大批量数据或交换数据,须要从文本中导入数据或导出数据到文本。
1、 创建测试表,准备数据
首先创建一个用于测试的表示学生信息的表,字段有id、姓名、年龄、城市、薪水。Id和姓名不
能为空。测试
[c-sharp] view plain copyspa
建立表截图以下:
接着写一个用于导入的文本文件:c:/data.txt。
张三 31 北京 3000
李四 25 杭州 4000
王五 45 /N 4500
小明 29 天津 /N
每一项之间用Tab键进行分隔,若是该字段为NULL,则用/N表示。
2、 导入数据
输入命令,进行导入。 操作系统
[c-sharp] view plain copy.net
导入数据截图以下:
其中local表示本地。执行后,能够看到NULL数据也被正确地导入。
3、 导出数据
如今将这个表导出为文本文件:c:/data_out.txt。code
[c-sharp] view plain copyblog
导出数据截图以下:
其中lines terminated by “/r/n”表示每一行(即每一条记录)用/r/n分隔,/r/n是window系
统的换行符。导出的data_out.txt与data.txt的内容彻底同样。
4、 运行环境
Windows vista home basic
MySQL 5.1.34-community
5、 注意
字段之间的分隔和记录(行)之间的分隔默认是/t(即Tab)和/n。但能够改变,如:
FIELDS TERMINATED BY ',' --字段用,进行分隔
LINES TERMINATED BY ';' --记录用; 进行分隔
另外要注意其它操做系统的换行符与windows可能不相同。ip