MySQL LOAD DATA LOCAL INFILE仅导入一行

dev*_*lis 6 mysql sql csv import phpmyadmin

我们有一个包含数千条记录的CSV文件.我想通过phpmyadmin将这些行导入MySQL表.这是使用的命令:

load data local infile '/var/www/html/deansgrads_201280.csv' 
into table ttu_nameslist
fields terminated by ','
enclosed by '"'
lines terminated by '\r\n'
(firstname, middlename, lastname, city, county, state, termcode, category)
Run Code Online (Sandbox Code Playgroud)

表中有一个ID字段设置为自动递增.当我们执行此SQL时,只将第一行导入表中.

输入数据文件行:

"Aaron","Al","Brockery","Cookeville","Putnam","TN","201280","deanslist"
"Aaron","Dan","Mickel","Lebanon","Wilson","TN","201280","deanslist"
Run Code Online (Sandbox Code Playgroud)

表结构:

CREATE TABLE `ttu_nameslist` (
  `id` int(11) NOT NULL,
  `firstname` varchar(50) NOT NULL,
  `middlename` varchar(50) NOT NULL,
  `lastname` varchar(50) NOT NULL,
  `city` varchar(50) NOT NULL,
  `county` varchar(50) NOT NULL,
  `state` varchar(2) NOT NULL,
  `termcode` varchar(6) NOT NULL,
  `category` varchar(10) NOT NULL,
  PRIMARY KEY (`id`)
 ) ENGINE=MyISAM DEFAULT CHARSET=latin1
Run Code Online (Sandbox Code Playgroud)

我做错了为什么在添加一行后它会退出?

Rad*_*zea 8

你说ID字段有AUTO_INCREMENT属性,但在CREATE TABLE语句中没有提到它.这是问题的一部分.

另一部分是那些截断警告.CSV文件中的某些行可能包含太长而无法放入列中的数据.将这些文本列的大小增加到更大的值(假设为200),然后重试.

您确定CSV文件有效吗?(也就是每行具有相同数量的值等).您应该检查这些字符串是否包含逗号(,),尽管这不应该是一个问题.

  • 我同意缺乏自动增量.如果它试图为每一行插入0,我会不会感到惊讶,并且由于一个关键的冲突,除了1以外都失败了. (3认同)

Eri*_*ski 5

为什么MySQL LOAD DATA INFILE命令只加载一行?

发生了什么事情是你加载第一列罚款,然后加载第二列,它失败,因为违反了唯一的索引约束.

MySQL LOAD DATA LOCAL INFILE将在列上强制执行您的唯一索引,然后跳过任何有问题的重复行而不对其执行任何操作,甚至不记录警告!

如何重现这个phenemenon:

  1. 创建一个包含int和varchar列的表:

    mysql> create table foo(id INT, mytext VARCHAR(255));
    Query OK, 0 rows affected (0.02 sec)
    
    Run Code Online (Sandbox Code Playgroud)
  2. 在varchar列上添加唯一约束:

    mysql> alter table foo add constraint my_epic_constraint unique(mytext);
    Query OK, 0 rows affected (0.02 sec)
    Records: 0  Duplicates: 0  Warnings: 0
    
    Run Code Online (Sandbox Code Playgroud)
  3. 创建输入文本文件/tmp/foo.txt,由制表符分隔,这违反了唯一约束:

    1   fred
    2   fred
    
    Run Code Online (Sandbox Code Playgroud)
  4. 尝试导入它:

    mysql> load data local infile '/tmp/foo.txt' into table foo fields 
           terminated by '\t' lines terminated by '\n' (@col1,@col2) 
           set id=@col1, mytext=@col2;
    
    Query OK, 1 row affected (0.01 sec)
    Records: 2  Deleted: 0  Skipped: 1  Warnings: 0
    
    Run Code Online (Sandbox Code Playgroud)

BAM!这是你的问题:为什么它只导入一行?因为您有一个唯一的键约束,数据文件中的行被违反.

解决方案:

  1. 删除表上的唯一键约束,然后重试.

  2. 进入文本文件并删除违反唯一约束的重复行.


小智 5

我遇到了同样的问题,我使用双引号“\r\n”而不是“\r\n”解决了