mysql load 内容多行_MySQL LOAD DATA与多行数据

bd96500e110b49cbb3cd949968f18be7.png

I'm having problems with Mysql's LOAD DATA command.

With simple data, it works fine.

When I try to load in data which is long, and has a field which extends over many lines, it fails.

Here's my input data. Fields are tab-delimited.

1 2008-06-27 12:00:00 Type-Safe Enumerations title Fr 5

...line 1..

...line 2....

\N 2002-10-01 12:00:00 END-OF-THE-LINE

2 2008-06-27 12:00:00 Class for constants Classe pour constantes 1

line 1...

..line 2..

\N 2002-10-01 12:00:00 END-OF-THE-LINE

4 2008-06-27 12:00:00 Another Énumérations 5

line 1

line 2

\N 2002-10-01 12:00:00 END-OF-THE-LINE

5 2008-06-27 12:00:00 And Another Énumérations 5

line 1

line 2

\N 2002-10-01 12:00:00 END-OF-THE-LINE

And here's the LOAD DATA command:

>LOAD DATA LOCAL INFILE "TopicInfileText2.dat" INTO TABLE Topic

LINES TERMINATED BY "END-OF-THE-LINE";

The target table :

CREATE TABLE Topic (

Id SMALLINT UNSIGNED NOT NULL AUTO_INCREMENT,

LastEdit TIMESTAMP NOT NULL,

TitleEnglish VARCHAR(75) NOT NULL,

TitleFrench VARCHAR(75),

ChapterId SMALLINT NOT NULL References Chapter,

BodyEnglish TEXT NOT NULL,

BodyFrench TEXT,

CreationDate DATETIME NOT NULL,

PRIMARY KEY (Id)

);

Warnings from MySQL

| Incorrect integer value: '

2' for column 'Id' at row 2 |

| Incorrect integer value: '

4' for column 'Id' at row 3 |

| Warning | 1366 | Incorrect integer value: '

5' for column 'Id' at row 4 |

| Warning | 1366 | Incorrect integer value: '

' for column 'Id' at row 5 |

解决方案

The error was in the LOAD DATA command. I was missing a newline character.

Should have been:

LOAD DATA LOCAL INFILE "TopicInfileText2.dat" INTO TABLE

Topic LINES TERMINATED BY "END-OF-THE-LINE\n";

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值