我们有一个包含数千条记录的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","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文件有效吗? (a.k.a.每行具有相同数量的值等).您应该检查这些字符串是否包含逗号(,),尽管这不应该是一个问题.