我们有一个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)

表中有一个ID字段,设置为自动递增。当我们执行此SQL时,仅第一行被导入到表中。

输入数据文件行:
"Aaron","Al","Brockery","Cookeville","Putnam","TN","201280","deanslist"
"Aaron","Dan","Mickel","Lebanon","Wilson","TN","201280","deanslist"

表结构:
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

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

最佳答案

您说ID字段具有AUTO_INCREMENT属性,但是CREATE TABLE语句中没有提及它。这是问题的一部分。

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

您绝对确定CSV文件有效吗? (又称每行具有相同数量的值,等等)。您可能应该检查这些字符串是否包含逗号(,),尽管这不成问题。

关于MySQL LOAD DATA LOCAL INFILE仅导入单行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14614519/

10-09 20:21
查看更多