导入CSV到Mysql期间的NULL字段

时间:2016-10-05 09:49:57

标签: php mysql sql csv import

我必须使用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?

你能帮助我吗? 谢谢!

1 个答案:

答案 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);