将 csv 导入 mysql workbench 时的列名要求

Column Name requirement while importing csv into mysql workbench

我有以下代码将选定的列导入 mysql workbench。

    SET autocommit=0;
    LOAD DATA LOCAL INFILE '150926.csv' INTO TABLE innodb.fh  FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n' ignore 1 lines
    (@dummy,date,@dummy,@dummy,@dummy,**CS-URI-STEM**,@dummy,@dummy,@dummy,c-ip,@dummy,@dummy,@dummy,@dummy,@dummy,@dummy, session_id,@dummy,@dummy,@dummy);

    COMMIT;

问题是我的 csv 文件中有一个名为 "CS-URI-STEM" 的列,而我的代码无法正常工作。我只是想知道我是否需要更改我的 csv 文件中的列名称,因为它包含破折号。或者如果我需要更改代码,请告诉我。非常感谢!!!!!!

括号中的列名不是文件中的列名,它们是您要导入的 table 中的列名。如果您将其视为插入查询中的列名或值列表,则会令人困惑,因为它们的工作方式不同 - 此处您指定文件中的哪一列(按列表中的位置)进入 table 中的哪一列(通过 table 中列的名称)。您必须忘记文件中的列名,因为它们根本不重要。

例如:给定这样一个 CSV 文件:

Row Number,Date,IP,Session,Whatever,Other columns...
1,2016-01-01,10.0.0.1,21312,"ABC",...
2,2016-01-02,10.0.0.2,21889,"XYZ",...

还有一个 table 这样的:

| session_id | ip_address | action_date | session_description |

导入的相应列名称列表为:

(@dummy,action_date,ip_address,session_id,session_description,@dummy,@dummy,@dummy,...)

事实上,如果您只需要从第一列导入数据(即,如果您只需要前五列的数据,但文件有 10 列,则可以省略尾随虚拟变量,您只能在导入列表中写入五列。)MySQL 会给出关于 (#1262, "Row X was truncated; it contained more data than there were input columns") 的警告,但它会导入数据.