我必须使用PHP脚本在MySql数据库的表中导入CSV文件。 CSV文件如下:
"giorno","lmedollton","changedolleuro","euroton","lmesterton","delnotiz","girm","sgm"
"2016-09-02", "100.01", "4005.09", "5000", "1.09", "120.09", "100.5", "200.77"
"2016-09-03", "150.01", "4205.09", "5600", "1.10", "150.09", "300.5", "300.77"
表结构如下:
# Campo Tipo Collation Attributi Null
1 id int(20) No Nessuno AUTO_INCREMENT
2 giorno date Sì NULL
3 lmedollton float Sì NULL
4 changedolleuro float Sì NULL
5 euroton float Sì NULL
6 lmesterton float Sì NULL
7 delnotiz float Sì NULL
8 girm float Sì NULL
9 sgm float Sì NULL
有两个问题:
1)使用这个PHP代码:
$csvFile = "../scripts/tabella.csv";
$db = @mysql_connect('***', '***', '***');
@mysql_select_db('***');
$query = 'LOAD DATA LOCAL INFILE \' '. $csvFile .' \' INTO TABLE rame FIELDS TERMINATED BY \',\' ENCLOSED BY \'"\' LINES TERMINATED BY \'\n\'
(giorno,lmedollton,changedolleuro,euroton,lmesterton,delnotiz,girm,sgm)';
if(!mysql_query($query)){
die(mysql_error());
}
//@mysql_query($query);
mysql_close($db);
mysql_error返回'找不到文件';我也尝试使用realpath函数,但错误是一样的。 CSV文件位于www.valuebiz.it/valuebiz/scripts/tabella.csv中的站点服务器中,其权限为777.使用此路径如URL,我可以正确下载tabella.csv。 我使用哪条路径是正确的?
2)我尝试在我的localhost中运行查询并运行,但添加的记录的每个字段都是NULL。该表有9个字段,包括id字段(自动增量):第一个是DATE类型,其他是FLOAT类型。 为什么插入值为NULL?
你能帮助我吗? 谢谢!答案 0 :(得分:0)
我发现导入尝试存在三个主要问题。首先,如果文件路径错误,则不会移动任何内容。其次,您应该在命令末尾使用IGNORE 1 LINES
告诉MySQL您的CSV文件在开头有一行标题。第三,我认为你应该使用LOAD DATA INFILE
,而不是LOAD DATA LOCAL INFILE
,因为你从服务器而不是客户端执行此代码。尝试以下几点:
<强>窗:强>
LOAD DATA INFILE 'C:/path/to/data.csv' INTO TABLE rame
FIELDS TERMINATED BY ',' ENCLOSED BY '"'
LINES TERMINATED BY '\r\n'
IGNORE 1 LINES
(giorno, lmedollton, changedolleuro, euroton, lmesterton, delnotiz, girm, sgm);
<强> Unix的:强>
LOAD DATA INFILE '\path\to\data.csv' INTO TABLE rame
FIELDS TERMINATED BY ',' ENCLOSED BY '"'
LINES TERMINATED BY '\n'
IGNORE 1 LINES
(giorno, lmedollton, changedolleuro, euroton, lmesterton, delnotiz, girm, sgm);