mysql导入大txt_mysql如何高速导入导出有一定格式大容量TXT文本

mysql如何高速导入导出有一定格式大容量TXT文本

先谈谈如何mysql导入TXT

用到loaddata, MySQL的LOAD DATA INFILE语句用于高速地从一个文本文件中读取行,并装入一个表中。LOAD

DATA INFILE语句从一个文本文件中以很高的速度读入一个表中。

load data参数配置:

SQL代码

LOADDATA [LOW_PRIORITY] [LOCAL] INFILE'file_name.txt(file路径)'[REPLACE|IGNORE]

INTOTABLEtbl_name

[FIELDS

[TERMINATED BY'\t']

[OPTIONALLY] ENCLOSED BY'']

[ESCAPED BY'\\' ]]

[LINES TERMINATED BY '\n']

[IGNOREnumber LINES]

[(col_name,...)]

如果指定LOCAL关键词,从客户本地主机读文件。如果LOCAL没指定,文件必须位于服务器上(远程用的)。(LOCAL在MySQL3.22.6或以后版本中可用。)如果你指定关键词LOW_PRIORITY,LOAD

DATA语句的执行被推迟到没有其他客户读取表后。REPLACE和IGNORE关键词控制对现有的唯一键记录的重复的处理。如果你指定REPLACE,新行将代替有相同的唯一键值的现有行。如果你

指定IGNORE,跳过有唯一键的现有行的重复行的输入。如果你不指定任何一个选项,当找到重复键键时,出现一个错误,并且文本文件的余下部分被忽略时。如果你使用LOCAL关键词从一个本地文件装载数据,服务器没有办法在操作的当中停止文件的传输,因此缺省的行为好像IGNORE被指定一样。LOAD

DATA INFILE是SELECT ... INTO

OUTFILE的逆操作,SELECT句法。为了将一个数据库的数据写入一个文件,使用SELECT ... INTO

OUTFILE,为了将文件读回数据库,使用LOAD DATA

INFILE。两个命令的FIELDS和LINES子句的语法是相同的。两个子句是可选的,但是如果指定两个,FIELDS必须在LINES之前。

如果你指定一个FIELDS子句,它的每一个子句(TERMINATED BY, [OPTIONALLY] ENCLOSED

BY和ESCAPED BY)也是可选的,除了你必须至少指定他们之一。

如果你不指定一个FIELDS子句,缺省值与如果你这样写的相同:

FIELDS TERMINATED BY '\t' ENCLOSED BY '' ESCAPED BY '\\'

如果你不指定一个LINES子句,缺省值与如果你这样写的相同:

LINES TERMINATED BY '\n'换句话说,缺省值导致读取输入时,LOAD

DATA INFILE表现如下:

在换行符处寻找行边界在定位符处将行分进字段不要期望字段由任何引号字符封装将由“\”开头的定位符、换行符或“\”解释是字段值的部分字面字符相反,缺省值导致在写入输出时,SELECT ... INTO OUTFILE表现如下:

在字段之间写定位符不用任何引号字符封装字段使用“\”转义出现在字段中的定位符、换行符或“\”字符在行尾处写换行符注意,为了写入FIELDS ESCAPED BY

'\\',对作为一条单个的反斜线被读取的值,你必须指定2条反斜线值。

IGNORE number LINES选项可被用来忽略在文件开始的一个列名字的头:

mysql> LOAD DATA INFILE "/tmp/file_name" into table test

IGNORE 1 LINES;

我建了一个demo表:

SQL代码

mysql> use DB_cmd_demo;

mysql> explain insertdemo;

+-------+-------------+------+-----+---------+-------+

| Field | Type | Null|Key|Default| Extra |

+-------+-------------+------+-----+---------+-------+

| code | varchar(25) | YES | |NULL| |

| demo | varchar(15) |NO| | | |

+-------+-------------+------+-----+---------+-------+

2 rowsinset(0.01 sec)

File_AA.txt文本格式如下:

XML/HTML代码

AAVTUALOJJKEC

AAHRFTXIBLGYG

AAOAQVLJROSBT

AACNKRKBZEDPE

SQL代码

mysql>loaddatalocalinfile'd:\File_AA.txt'intotableinsertdemo (demo);

Query OK, 4 rowsaffected (0.00 sec)

Records: 4 Deleted: 0 Skipped: 0 Warnings: 0

生成如下:

SQL代码

mysql>select*frominsertdemo;

+------+----------------+

| code | demo |

+------+----------------+

| NULL| AACNKRKBZEDPE |

| ULL | AAOAQVLJROSBT

| ULL | AAHRFTXIBLGYG

| ULL | AAVTUALOJJKEC

+------+----------------+

4 rowsinset(0.00 sec)

再谈谈mysql如何导出到TXT

这是网上的一个demo,在这里贴一下,其实两个用法主要是理解每个参数的用法就OK了

SQL代码

-- 导出数据为文本文件

SELECTdemo,code

INTOOUTFILE'd:\DM_HY_EXPORT.TXT'

FIELDS TERMINATED BY','OPTIONALLY ENCLOSEDBY''''

LINES TERMINATED BY'\n'

FROMinsertdemo;

FIELDS TERMINATED BY','数据字段间用逗号隔开

OPTIONALLY ENCLOSED BY''''每个字段的数据用单引号括住(注意单引号的表达方法)

LINES TERMINATED BY'\n'每条数据结束用'\n'作为换行符。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值