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 分割

导入文件示例

在这里插入图片描述

load data infile "Pet.log" into table bi_pet
 character set utf8mb4
  fields terminated by "," 
  Enclosed By \'"\' 
  LINES TERMINATED BY \'\n\'
(log_ymd,log_ym,`year`,`month`,`day`,`hour`,`minute`,`week`,role_id,operate,pet_info,item,lotto,exp,operate_type,other_info,appid,msid,`server`);
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值