mysql - LOAD DATA LOCAL INFILE 不导入任何记录

标签 mysql csv mysql-workbench csv-import

我正在从事一个需要使用 Workbench 将 csv 数据导入 mysql 表的项目。我尝试运行下面的命令。我没有收到任何错误,但是没有记录被导入到表中。请注意,我尝试将终止于 \n 的行更改为 \r,结果相同。

我很感激任何关于如何解决的建议。

这是我试过的查询:

LOAD DATA LOCAL INFILE 'data-to-import.csv' INTO TABLE db.t1
COLUMNS TERMINATED BY ','
LINES TERMINATED BY '\r\n' 
IGNORE 1 LINES
(id,age,spns,pns,spns2,sns,ps,ss,gid,term,band)

导入数据.csv

 ,18,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,19,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,20,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,21,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,22,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,23,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,24,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,25,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,26,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,27,0.455,0.62,0.774,1.083,2.408,3.702,1,10,1
 ,28,0.455,0.62,0.774,1.088,2.416,3.702,1,10,1
 ,29,0.455,0.62,0.792,1.121,2.489,3.702,1,10,1

db.t1 定义

   CREATE TABLE `t1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `age` int(11) NOT NULL,
  `spns` decimal(4,4) NOT NULL,
  `pns` decimal(4,4) NOT NULL,
  `spns2` decimal(4,4) NOT NULL,
  `sns` decimal(4,4) NOT NULL,
  `ps` decimal(4,4) NOT NULL,
  `ss` decimal(4,4) NOT NULL,
  `gid` int(11) NOT NULL,
  `term` int(11) DEFAULT NULL,
  `band` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

最佳答案

在查看您的 SQL 时,您的行终止符似乎有问题。

试试这个:

LOAD DATA LOCAL INFILE 'data-to-import.csv' INTO TABLE db.t1
COLUMNS TERMINATED BY ','
ENCLOSED BY '"' 
LINES TERMINATED BY '\r\n' 
IGNORE 1 LINES
(id,age,spns,pns,spns2,sns,ps,ss,gid,term,band)

如果您的文件来自 Windows,则行终止符为 CR/LF。你有它作为 LF/CR。

如果文件来自 *nux,您的行终止符只是一个换行符,在这种情况下您的 SQL 将如下所示:

LOAD DATA LOCAL INFILE 'data-to-import.csv' INTO TABLE db.t1
COLUMNS TERMINATED BY ','
ENCLOSED BY '"' 
LINES TERMINATED BY '\n' 
IGNORE 1 LINES
(id,age,spns,pns,spns2,sns,ps,ss,gid,term,band)

希望这对您有所帮助!


我刚刚运行了以下代码:

drop schema if exists db;
create schema db;
use db;

CREATE TABLE `t1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `age` int(11) NOT NULL,
  `spns` decimal(4,4) NOT NULL,
  `pns` decimal(4,4) NOT NULL,
  `spns2` decimal(4,4) NOT NULL,
  `sns` decimal(4,4) NOT NULL,
  `ps` decimal(4,4) NOT NULL,
  `ss` decimal(4,4) NOT NULL,
  `gid` int(11) NOT NULL,
  `term` int(11) DEFAULT NULL,
  `band` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

LOAD DATA LOCAL INFILE 'c:/temp/data-to-import.csv' INTO TABLE db.t1
COLUMNS TERMINATED BY ','
LINES TERMINATED BY '\r\n' 
IGNORE 1 LINES
(id,age,spns,pns,spns2,sns,ps,ss,gid,term,band);

SELECT * FROM t1;

我从您发布的数据中复制了数据并将其放入我的临时文件夹中。工作正常。

首先,您发布的数据没有标题行,所以我不确定为什么您在其中有 IGNORE 1 LINES。

此外,像我一样尝试在文件名上加上路径,看看是否可行。

如果没有,请告诉我文件的来源。它仍然可能是行终止符问题。


好的,根据我们的聊天,您正在 Mac OSX 上运行并且行终止符是“\r”。只需使用它,您就可以开始了。

关于mysql - LOAD DATA LOCAL INFILE 不导入任何记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48545566/

相关文章:

MySQL 在 UPDATE 语句中添加到列的内容

mysql - 连接两个表并从一列返回多个匹配项的 SQL 查询?

php - 通过主键链接两个表中的多列

mysql - 存储过程中的 case 语句问题

mysql - 如何对特定唯一值的实例总数求和

php - wordpress如何存储wp_usermeta?

java - BigQuery - 导出 CSV 某些列

objective-c - 使用 CHCSVWriter 保存 CSV 文件

javascript - 定义 D3 插件 sankey.js 和 html 代码之间的源

mysql - 如何在 Workbench 中为 MySQL 表指定 DateTime()