MySQL 使用LOAD DATA INFILE 快速导入文件

load data infile语句从一个文本文件中以很高的速度读入一个表中。
使用这个命令之前,mysqld进程(服务)必须已经在运行。为了安全原因,当读取位于服务器上的文本文件时,文件必须处于数据库目录或可被所有人读取。
另外,为了对服务器上文件使用load data infile,在服务器主机上你必须有file的权限。

SQL语句

基本语法
load data  [low_priority] [local] infile 'file_name txt' [replace | ignore]
into table tbl_name
[fields
[terminated by't']
[OPTIONALLY] enclosed by '']
[escaped by'\' ]]
[lines terminated by'n']
[ignore number lines]
[(col_name,   )];

简单示例
load data infile '文件路径' low_priority  into table 表名 
character set utf8mb4 
fields terminated by ',' 
Enclosed By '"' 
LINES TERMINATED BY '\n' (`字段列表`);

low_priority
如果你指定关键词low_priority,那么MySQL将会等到没有其他人读这个表的时候,才把插入数据。

replace和ignore关键词控制对现有的唯一键记录的重复的处理。如果你指定replace,新行将代替有相同的唯一键值的现有行。如果你指定ignore,跳过有唯一键的现有行的重复行的输入。如果你不指定任何一个选项,当找到重复键时,出现一个错误,并且文本文件的余下部分被忽略
适合加了唯一索引的字段

character set utf8mb4
设置编码格式,防止中文乱码(也可不设置)

fields terminated by ‘,’
指定导入文件的字段的分割符

Enclosed By ’ " ’
如果数据被某种符号封闭着,需要指定 ‘ fields enclosed by ’ :

LINES TERMINATED BY ‘\n’ (字段列表);
字段列表忽略自增索引
每条数据以 \n 分割

导入文件示例

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_41049126/article/details/93716970